Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 04.03.2018
Сообщений: 40
Excel

ReDim Preserve в двумерном массиве

01.10.2021, 12:00. Показов 2091. Ответов 12

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Пробую ниже следующий код, создается массив PolniySpisok, но при попытке увеличения границы массива выкидывает ошибку Run-time error '9': Subscribe out of Range

вроде все делаю по примеру Микрософта: https://docs.microsoft.com/ru-... -statement
где у меня косяк ? как исправить ?


Visual Basic
1
2
3
4
5
6
7
8
9
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Dim LastRow As Integer 'последняя строка
Dim PolniySpisok() As Variant 'массив
With ThisWorkbook.Sheets("Лист 1")
LastRow = Cells(Rows.Count, 4).End(xlUp).Row
PolniySpisok = .Range(.Cells(1, 1), Cells(LastRow, 2)).Value
ReDim Preserve PolniySpisok(LastRow, 4)
End With
End Sub
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.10.2021, 12:00
Ответы с готовыми решениями:

Как использовать ReDim Preserve для двумерного массива
Создали, например, mArr(n, 4). При определенном условии в ячейке первого столбца, нужно загнать в этот массив еще несколько значений из той...

Redim Preserve не работает
Если есть "Preserve" - то сразу ошибка - "Subscript out of range" в строке Redym Preserve. Без Preserve - всё работает нормально. А мне...

Массив Собственного Типа И Redim Preserve
Всем привет! Описан тип: Type myt p1 As String p2 As String End Type Объявлен массив:

12
Часто онлайн
 Аватар для КостяФедореев
982 / 632 / 279
Регистрация: 09.01.2017
Сообщений: 2,070
01.10.2021, 12:02
barsuuuk, косяк тут
Visual Basic
1
ReDim Preserve PolniySpisok(LastRow, 4)
можно увеличивать только второй аргумент и никак иначе
Visual Basic
1
ReDim Preserve PolniySpisok(4, LastRow)
0
0 / 0 / 0
Регистрация: 04.03.2018
Сообщений: 40
01.10.2021, 12:06  [ТС]
Я же увеличиваю второй аргумент

было:
Visual Basic
1
LastRow, 2
стало:
Visual Basic
1
LastRow, 4
0
run
 Аватар для I can
4751 / 4372 / 821
Регистрация: 13.04.2015
Сообщений: 9,436
01.10.2021, 12:13
Цитата Сообщение от barsuuuk Посмотреть сообщение
Preserve
А нафига нужен этот Preserve, если массив объявлен в этой же процедуре? Убрать его, и все дела.
0
0 / 0 / 0
Регистрация: 04.03.2018
Сообщений: 40
01.10.2021, 12:16  [ТС]
I can,
тогда все данные в массиве сотрутся.. а мне надо чтобы они остались и массив расширился
0
4085 / 1465 / 401
Регистрация: 07.08.2013
Сообщений: 3,663
01.10.2021, 12:41
Цитата Сообщение от barsuuuk Посмотреть сообщение
PolniySpisok = .Range(.Cells(1, 1), Cells(LastRow, 2)).Value
перед вторым Cells должна стоять точка
0
0 / 0 / 0
Регистрация: 04.03.2018
Сообщений: 40
01.10.2021, 12:50  [ТС]
snipe,
точку добавил, спасибо, но и без нее массив PolniySpisok создавался.
но следующей строкой ReDim Preserve PolniySpisok(LastRow, 4)
он категорически не расширяется
0
4085 / 1465 / 401
Регистрация: 07.08.2013
Сообщений: 3,663
01.10.2021, 12:56
возможно что LastRow пустая
вы же данные для этой переменной получаете из столбца D
Cells(Rows.Count, 4).End(xlUp).Row

Добавлено через 1 минуту
надо поставить точку останова и посмотреть значения переменных
0
1846 / 1161 / 354
Регистрация: 11.07.2014
Сообщений: 4,105
01.10.2021, 13:00
barsuuuk, исправьте строки 3 и 7
Visual Basic
1
2
Dim PolniySpisok 'массив
ReDim Preserve PolniySpisok(1 To LastRow, 1 To 4)
0
4085 / 1465 / 401
Регистрация: 07.08.2013
Сообщений: 3,663
01.10.2021, 13:04
Лучший ответ Сообщение было отмечено barsuuuk как решение

Решение

Попробуйте так
ReDim Preserve PolniySpisok(LastRow-1, 4)

Добавлено через 2 минуты
Отсчет строк в Ексель идет от 1
Отсчет элементов массива идет от 0
вы пытаетесь изменить две размерности массива чего делать ну ни как нежелательно
1
0 / 0 / 0
Регистрация: 04.03.2018
Сообщений: 40
01.10.2021, 13:08  [ТС]
snipe,

Спасибо, сделаю и отпишусь
0
1846 / 1161 / 354
Регистрация: 11.07.2014
Сообщений: 4,105
01.10.2021, 13:13
Интересно бы знать и зачем это размещено в
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
0
0 / 0 / 0
Регистрация: 04.03.2018
Сообщений: 40
01.10.2021, 13:18  [ТС]
snipe,

да , с размерностями накосячил,
Option Base 1 помогло

Всем спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.10.2021, 13:18
Помогаю со студенческими работами здесь

Работа с массивом не определенного размера ReDim Preserve
1. создается массив не определенного размера 2.по мере считывания строк из файла массив заполняется меняя размерность(работает нормально)...

Как в С# реализовать VB'шный оператор: ReDim Preserve buf(N)
1. У объекта Obj есть метод со следующей сигнатурой: Method(ref System.Array b) Мне надо передать ему массив double d. Не...

Алгоритм расчёта суммы и произведения элементов в одномерном массиве и двумерном массиве и его модификация
алгоритм расчёта суммы и произведения элементов в одномерном массиве и двумерном массиве и его модификация

Transform-style: preserve-3d;
Добрый день. На этом сайте есть карточки отелей, которые переворачиваются при наведении. Проблема в том, что сделано это с...

В двумерном массиве
помогите плиз... срочно нужно... спс. В двумерном массиве хранится информация о количестве учени¬ков в каждом классе каждой параллели...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
JWT аутентификация в ASP.NET Core
UnmanagedCoder 18.06.2025
Разрабатывая веб-приложения, я постоянно сталкиваюсь с дилеммой: как обеспечить надежную аутентификацию пользователей без ущерба для производительности и масштабируемости? Классические подходы на. . .
Краткий курс по С#
aaLeXAA 18.06.2025
Здесь вы найдете все необходимые функции чтоб написать програму на C# Задание 1: КЛАСС FORM 1 public partial class Form1 : Form { Spisok listin = new Spisok(); . . .
50 самых полезных примеров кода Python для частых задач
py-thonny 17.06.2025
Эффективность работы разработчика часто измеряется не количеством написаных строк, а скоростью решения задач. Готовые сниппеты значительно ускоряют разработку, помогают избежать типичных ошибок и. . .
C# и продвинутые приемы работы с БД
stackOverflow 17.06.2025
Каждый . NET разработчик рано или поздно сталкивается с ситуацией, когда привычные методы работы с базами данных превращаются в источник бессонных ночей. Я сам неоднократно попадал в такие ситуации,. . .
Angular: Вопросы и ответы на собеседовании
Reangularity 15.06.2025
Готовишься к техническому интервью по Angular? Я собрал самые распространенные вопросы, с которыми сталкиваются разработчики на собеседованиях в этом году. От базовых концепций до продвинутых. . .
Архитектура Onion в ASP.NET Core MVC
stackOverflow 15.06.2025
Что такое эта "луковая" архитектура? Термин предложил Джеффри Палермо (Jeffrey Palermo) в 2008 году, и с тех пор подход только набирал обороты. Суть проста - представьте себе лук с его. . .
Unity 4D
GameUnited 13.06.2025
Четырехмерное пространство. . . Звучит как что-то из научной фантастики, правда? Однако для меня, как разработчика со стажем в игровой индустрии, четвертое измерение давно перестало быть абстракцией из. . .
SSE (Server-Sent Events) в ASP.NET Core и .NET 10
UnmanagedCoder 13.06.2025
Кажется, Microsoft снова подкинула нам интересную фичу в новой версии фреймворка. Работая с превью . NET 10, я наткнулся на нативную поддержку Server-Sent Events (SSE) в ASP. NET Core Minimal APIs. Эта. . .
С днём независимости России!
Hrethgir 13.06.2025
Решил побеседовать, с утра праздничного дня, с LM о завоеваниях. То что она написала о народе, представителем которого я являюсь сам сначала возмутило меня, но дальше только смешило. Это чисто. . .
Лето вокруг.
kumehtar 13.06.2025
Лето вокруг. Наполненное бурями и ураганами событий. На фоне магии Жизни, священной и вечной, неумелой рукой человека рисуется панорама душевного непокоя. Странные серые краски проникают и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
OSZAR »