Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
1 / 1 / 1
Регистрация: 29.08.2015
Сообщений: 47

Заполнение динамического массива

17.04.2019, 07:46. Показов 1971. Ответов 3
Метки 20 (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
У меня проблемы с массивами.
в столбце A есть значения "Итого:" в количестве 7-8 шт.
Мне нужно записать в массив номер строк всех этих 7-8 шт.


Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
Sub test()
 
Dim Massiv2() As Integer
 
For i = 1 To 200
 
If Cells(i, 1) = "Итого:" Then Massiv2() = i
 
Next i
 
 
End Sub
С массивами если честно не сталкивался, поэтому прошу помощи.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.04.2019, 07:46
Ответы с готовыми решениями:

Заполнение динамического массива
Коллеги, помогите пожалуйста. В строке 3 находятся данные. Пытаюсь заполнить массив начиная со второго столбца и до конца, но...

Заполнение динамического массива с листа Excel
Добрый день! Столкнулась с такой задачей: необходимо создать процедуру ReadArray для считывания данных из электронной таблицы и...

Заполнение динамического массива
procedure TForm1.LoadListItem; var Item:TListItem; i,j: integer; s,s1: String; begin LoadString; j:=0; ...

3
4089 / 1469 / 401
Регистрация: 07.08.2013
Сообщений: 3,671
17.04.2019, 08:17
Лучший ответ Сообщение было отмечено pashulka как решение

Решение

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
Sub test()
Dim Massiv2&(), j&, i&
j = 0
For i = 1 To 200
If Cells(i, 1) = "Итого:" Then
ReDim Preserve Massiv2(j)
Massiv2(j) = i
j = j + 1
End If
Next i
End Sub
1
 Аватар для pashulka
4139 / 2243 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
17.04.2019, 08:24
Лучший ответ Сообщение было отмечено Шалкар как решение

Решение

Ещё вариант :

Visual Basic
1
2
3
4
5
6
7
8
Private Sub Test1()
    Dim r As Range, c As Range, a&(), i&
    Set r = Range("A1", Cells(Rows.Count, "A").End(xlUp))
    ReDim a(1 To Application.CountIf(r, "Итого:"))
    For Each c In r
        If c = "Итого:" Then i = i + 1: a(i) = c.Row
    Next
End Sub
Visual Basic
1
2
3
4
5
6
7
8
9
10
Private Sub Test2()
    Dim a1 As Variant, a2&(), i1&, i2&
    a1 = Range("A1", Cells(Rows.Count, "A").End(xlUp)).Value
    For i1 = 1 To UBound(a1)
        If a1(i1, 1) = "Итого:" Then
           ReDim Preserve a2(i2)
           a2(i2) = i1: i2 = i2 + 1
        End If
    Next
End Sub

P.S. Если допускается замена массива на коллекцию, то :

Visual Basic
1
2
3
4
5
6
7
Private Sub Test3()
    Dim a As Variant, i&, cl As New Collection
    a = Range("A1", Cells(Rows.Count, "A").End(xlUp)).Value
    For i = 1 To UBound(a)
        If a(i, 1) = "Итого:" Then cl.Add i
    Next
End Sub
1
1 / 1 / 1
Регистрация: 29.08.2015
Сообщений: 47
17.04.2019, 08:28  [ТС]
Спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.04.2019, 08:28
Помогаю со студенческими работами здесь

Заполнение динамического массива
Нужно заполнить массив цыфрами с ввода пользователя, пощитать их и добавить. С простым я понимаю как package com.company; import...

Заполнение динамического массива
Функция для записи и хранения имён текстовых файлов из папки (использование векторов (vector) запрещено, только массивы). После выполнения...

Заполнение динамического массива в С#
Пытаюсь заполнить массив элементами от начального значения (demarrer) до конечного (finale) с определенным шагом (etape). В С# разбираться...

Заполнение динамического массива
Хочу вручную заполнить динамический массив. В последний элемент массива после заполнении записывается какое-то левое число, не подскажите...

Заполнение динамического массива в подпрограмме
Что-то до меня не доходит как работают эти динамические массивы, а точнее как использовать с ними подпрограммы, так что прошу вашей помощи...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru