Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
1082 / 521 / 142
Регистрация: 27.02.2013
Сообщений: 1,501
1

Формирование содержания массива с листа

01.04.2016, 09:43. Показов 763. Ответов 10
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день .
На листе1 имеется таблица цветов(469 цветов).В коде программы используется массив со значениями кодов всех цветов.Однако каждый раз мне необходим массив не всех цветов,а только тех,которые определяются в таблице2.Подскажите пожалуйста быстрый способ формирования данных из ячеек листа (столбец L) в тело массива в VBA.
Сейчас я копирую массив из VBA и вставляю на лист,где произвожу ввод нужных кодов вручную.Затем все это копирую обратно в код.Можно-ли это как-то автоматизировать.
Файл прилагаю.
Вложения
Тип файла: xls Пример.xls (87.0 Кб, 7 просмотров)
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.04.2016, 09:43
Ответы с готовыми решениями:

Формирование массива с листа. Исправить код
На рабочем листе есть массив-строка С(5,1,1,7,1,21,1). Из него формируется новый квадратный массив....

Автоматическое формирование содержания для нескольких Word документов
при создании макроса у меня появляется Application.Templates( _ ...

Цикл FOR, формирование содержания с другого КФ
Задачка: Создать командный файл с именем «Свое_имя.bat». В данном файле прописать команды для...

Формирование прайс-листа
Всем привет. Задача. Сделать прайс-лист с категориями и подкатегориями. Т.е по-умолчанию, все...

10
1082 / 521 / 142
Регистрация: 27.02.2013
Сообщений: 1,501
01.04.2016, 10:15  [ТС] 2
Код нужен для 2007.Просто на работе 2003 стоит,поэтому и пример в нем.
Пробовал копировать из ячеек в блокнот.Но там появляются лишние пробелы табуляции.А при разложении строки по столбцам исчезают запятые.
0
Заблокирован
01.04.2016, 10:57 3
Цитата Сообщение от OLEGOFF Посмотреть сообщение
быстрый способ формирования данных из ячеек листа (столбец L) в тело массива в VBA
чем не устраивает это -
Visual Basic
1
RGBConstantColorRaduga = Range([L2], [L2].End(xlDown)).Value
?
0
1082 / 521 / 142
Регистрация: 27.02.2013
Сообщений: 1,501
01.04.2016, 11:14  [ТС] 4
Shersh, мне нужен именно массив,т.к. он затем используется в дальнейших расчетах в виде функции.И завязан с другими функциями. Я в VBA не силен,но попробую.Просто при постоянном обращении к Range замедляется работа.
Подробности применнения находятся в теме
Задать имя цвета из библиотеки цветов
Просто при обращении ко всему массиву цвета мне не хватает памяти для обработки более 250х120 ячеек.

Добавлено через 6 минут
Может я немного не так описал задачу?
Необходимо по столбцу L составить текст (массив) хоть в блокноте,хоть на листе который я мог бы просто скопировать в код .
0
Заблокирован
01.04.2016, 11:38 5
OLEGOFF, сдается мне, что вы решаете задачу через одно место не с того конца...

Visual Basic
1
2
3
4
5
6
a = Range([L2], [L2].End(xlDown)).Value
ReDim b(LBound(a, 1) To UBound(a, 1))
For i = LBound(a, 1) To UBound(a, 1)
  b(i) = a(i, 1)
Next
Debug.Print Join(b, ",")
и копируйте куда хотите
1
1082 / 521 / 142
Регистрация: 27.02.2013
Сообщений: 1,501
01.04.2016, 11:46  [ТС] 6
Shersh,
Цитата Сообщение от Shersh Посмотреть сообщение
через одно место
это может быть,буду разбираться.
Спасибо за советы
0
3218 / 967 / 223
Регистрация: 29.05.2010
Сообщений: 2,086
01.04.2016, 11:47 7
Можно код и короче:
Visual Basic
1
2
    a = Application.Transpose(Range([L2], [L2].End(xlDown)).Value)
    Debug.Print Join(a, ",")
1
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
01.04.2016, 11:58 8
Да обычно на практике и двумерный массив ничуть не хуже, незачем транспозу мучить... Чуть дальнейший код скорректировать и всё.
Тем более что в старых версиях эта транспоза глючила на больших объёмах (начиная уже с 2000 элементов)
0
1082 / 521 / 142
Регистрация: 27.02.2013
Сообщений: 1,501
01.04.2016, 12:04  [ТС] 9
Извините ребята,не нашел откуда копировать?
0
Заблокирован
01.04.2016, 12:15 10
Цитата Сообщение от OLEGOFF Посмотреть сообщение
не нашел откуда копировать?
CTRL+G
1
1082 / 521 / 142
Регистрация: 27.02.2013
Сообщений: 1,501
01.04.2016, 12:19  [ТС] 11
Спасибо всем.Разобрался.
Просто этот массив применяется параллельно еще в двух программах.Поэтому и надо было через бубен сделать.
0
01.04.2016, 12:19
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.04.2016, 12:19
Помогаю со студенческими работами здесь

Формирование листа настройки
помогите решить две задачи. 1.Ситуация есть прайсы находящиеся на винте. в листе настройка по...

Формирование итогового листа в Excel
Очень нужно решить вот такую задачу. Есть форма первичного документа – путевой лист грузового...

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

Как создать коэффициент в ячейке листа, чтобы каждое новое значение меняло значение массива только в одной строке листа?
Дано: Имеется массив, расположенный на листе Excel 2010 в стлбце. Каждое число массива умножается...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru