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

Копирование строки массива в другой массив

06.12.2015, 20:53. Показов 7394. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер. Подскажите пожалуйста. Имею двумерный массив то есть по сути таблица строки и столбцы. Хочу нужные мне строки засунуть в другой двумерный массив. То есть если мое условие выполняется то i-я строка первого массива полностью добавляется в конец второго массива. Как это сделать? Спасибо!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.12.2015, 20:53
Ответы с готовыми решениями:

Копирование строки из одного массива в другой
Есть большой массив, который нужно разделить на два (пять, сто) Как скопировать строку из первого массива в любой другой с таким же...

Копирование массива поэлементно в другой массив
Всем привет. Задание такое : Не используя оператора присваивания для массивов написать программу поэлементно копирующий один массив в...

Копирование массива строк в другой массив
И так, есть небольшой фрагмент: string q = {"111","222"}; string f = q; ...

4
6082 / 1327 / 195
Регистрация: 12.12.2012
Сообщений: 1,023
06.12.2015, 23:12
Здравствуйте, Alt,
В VBA есть такая интересная фишка: переменная типа Variant может хранить не только скалярное значение, но и массив.

Эта особенность может оказаться очень удобной для вашего случая. Покажу ее использование на примере:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
Sub AddingArrayRowsToArray()
    'Создаем два массива массивов: целевой массив и массив-источник. Заполняем массивы.
    Dim arrayOfSrcRows() As Variant, arrayOfDesRows() As Variant
    ReDim arrayOfSrcRows(1 To 3) As Variant
    arrayOfSrcRows(1) = Array("Источник - строка 1, ячейка 1", "Источник - строка 1, ячейка 2", "Источник - строка 1, ячейка 3")
    arrayOfSrcRows(2) = Array("Источник - строка 2, ячейка 1", "Источник - строка 2, ячейка 2", "Источник - строка 2, ячейка 3")
    arrayOfSrcRows(3) = Array("Источник - строка 3, ячейка 1", "Источник - строка 3, ячейка 2", "Источник - строка 3, ячейка 3")
    ReDim arrayOfDesRows(1 To 3) As Variant
    arrayOfDesRows(1) = Array("Выходной - строка 1, ячейка 1", "Выходной - строка 1, ячейка 2", "Выходной - строка 1, ячейка 3")
    arrayOfDesRows(2) = Array("Выходной - строка 2, ячейка 1", "Выходной - строка 2, ячейка 2", "Выходной - строка 2, ячейка 3")
    arrayOfDesRows(3) = Array("Выходной - строка 3, ячейка 1", "Выходной - строка 3, ячейка 2", "Выходной - строка 3, ячейка 3")
    'Выводим целевой массив на лист.
    Cells(1).Resize(3, 3) = Application.Index(arrayOfDesRows, 0, 0)
    Range("A:C").EntireColumn.AutoFit
    'Теперь "засовываем", как вы выразились, в массив еще 2 строки из массива-источника.
    'Допустим, нам нужны 1-я и 3-я строки массива-источника.
    ReDim Preserve arrayOfDesRows(1 To 3 + 2) As Variant
    arrayOfDesRows(3 + 1) = arrayOfSrcRows(1)
    arrayOfDesRows(3 + 2) = arrayOfSrcRows(3)
    'Выводим обновленный массив на лист.
    Cells(5, 1) = "Массив после обновления:"
    Cells(6, 1).Resize(3 + 2, 3) = Application.Index(arrayOfDesRows, 0, 0)
End Sub
С уважением,
Аксима
1
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
07.12.2015, 10:23
1. подсчитываем количество нужных строк - можно сразу собирать коллекцию номеров строк.
2. создаём массив нужного размера
3. цикл по коллекции - цикл по строке - копируем данные в новый массив
4. выгружаем результат.
0
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
07.12.2015, 13:09
Alt, можно создать одномерный массив t() и заполнить его номерами отобранных строк. Тогда вместо создания нового двумерного массива можно обращаться к элементу i-й отобранной строки как
a(t(i), j)
0
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
07.12.2015, 13:19
Можно номера в коллекцию собирать, например:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
Sub tt()
Dim col As New Collection, x&
 
col.Add 11, "1"
col.Add 22, "2"
col.Add 33, "3"
 
For x = 1 To 3
MsgBox col(CStr(x))
Next
End Sub
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.12.2015, 13:19
Помогаю со студенческими работами здесь

Поэлементное копирование строки «Hello World» в другой символьный массив
Было вот такое задание "Написать программу поэле-ментногокопирования строки «Hello World» вдругой сим-вольный массив"вот мой код ...

Копирование из одного массива в другой массив одного объекта
Пытаюсь скопировать дного массива в другой массив один объект, но не выходит. Условие следующее. - есть созданные массивы: public...

Скопировать определенные строки массива в другой массив
Добрый вечер. Подскажите пожалуйста. Имею двумерный массив то есть по сути таблица строки и столбцы. Хочу нужные мне строки засунуть в...

перечислить строки массива не вошедших в другой массив
Добрый день, имеются два массива, причем второй меньшего размера по строкам повторяется в первом. Как эффективно сравнить два массива между...

Как отобрать строки массива по условию в другой массив?
Доброго времени суток уважаемые знатоки VBA! :), Хочу получить уникальный элемент "дело" в соответствии группа-код. Идея...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru