|
921 / 326 / 130
Регистрация: 07.04.2011
Сообщений: 1,731
|
|
Импорт диапазона из Excel в вариантный массив05.05.2015, 21:20. Показов 25240. Ответов 34
Метки нет (Все метки)
Всем доброго времени суток.Ребята,подскажите пожалуйста,как из Екселя выдернуть сразу диапазон ячеек со значениями и запихнуть в вариантный массив?3 дня уже курю гугл - и все никак не выйдет.В какую сторону хоть копать?
Могу создать вариантный массив,считать каждую ячейку в экселе отдельно,и запихнуть в данный массив.Но при объеме данных свыше 50 000 строк чтение довольно долго выходит.А эти данные еще и обработать надо. ПЫ.СЫ.Готовый код не прошу - просто пните в нужном направлении наброском кода.Что и куда копать. Спасибо!
0
|
|
| 05.05.2015, 21:20 | |
|
Ответы с готовыми решениями:
34
Как сделать вариантный импорт рисунков? Как лучше записать вариантный массив в текстовой (.txt) файл Чтение данных из диапазона (Excel) в массив (Delphi) |
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||||||
| 20.03.2019, 19:29 | ||||||
|
Данные находятся в екселе, заносятся в массив arr, их оттуда благополучно можно извлечь по номеру элемента, как Вы и показали в примере чуть выше, но результат работы вот этой строки всегда неверные или я что то не верно делаю:
Но при той же абсолютно записи SafeArrayGetLBound - число столбцов массива отображается верно. Не знаю что не так.
0
|
||||||
|
Модератор
3406 / 2177 / 354
Регистрация: 13.01.2012
Сообщений: 8,444
|
|
| 20.03.2019, 19:36 | |
|
Optimus11, судя по коду вы запрашиваете верхнюю границу первого измерения много мерного массива
Добавлено через 1 минуту Optimus11, покажите скрин экселя и назовите какие значения вам кажется должна вернуть функция Добавлено через 25 секунд ... и какие она реально возвращает
0
|
|
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||||||
| 20.03.2019, 21:26 | ||||||
|
Да скриншот с экрана екселя не нужен в принципе.
Вот 'nb строчки кода берут диапазон из екселя:
long iUBound; SafeArrayGetUBound(arr.parray, 2, &iUBound); // И соответственно iUBound получается равным = 1 long lUBound; SafeArrayGetLBound(arr.parray, 2, &lUBound);/ И соответственно lUBound получается равным = 4, соответствует ширине диапазона. Вот как то так получается.
0
|
||||||
|
Модератор
3406 / 2177 / 354
Регистрация: 13.01.2012
Сообщений: 8,444
|
|
| 22.03.2019, 07:59 | |
|
Optimus11, иии... какие вам значения не нравятся?
0
|
|
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|
| 22.03.2019, 08:44 | |
|
Вот это SafeArrayGetUBound(arr.parray, 2, &iUBound), где iUBound=1
![]() Я понимаю, что я чего то не понимаю, но хотелось бы получить номер нижней границы массива по вертикали, но немогу реально понять как.
0
|
|
|
Модератор
3406 / 2177 / 354
Регистрация: 13.01.2012
Сообщений: 8,444
|
|||||||
| 23.03.2019, 16:19 | |||||||
|
Optimus11, я вас не понимаю. вот есть код
1
|
|||||||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||
| 23.03.2019, 23:09 | ||
0
|
||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|||||||||||||||||||||
| 24.03.2019, 19:36 | |||||||||||||||||||||
|
А может быть можете пожалуйста подсказать в чем разница между:
1)
Но, когда создается variant массив и туда записываются данные для последующей записи в екель:
Не пойму почему так. 2) И если можно такой вопрос: правильно ли я понимаю, что разница между VT_R8 и VT_R4 - только в разрядности виндовса ? То есть если у меня виндовс 64-разр., то условие:
0
|
|||||||||||||||||||||
|
Модератор
3406 / 2177 / 354
Регистрация: 13.01.2012
Сообщений: 8,444
|
|
| 24.03.2019, 20:35 | |
|
Optimus11, 1) в ячейках excel хранится VARIANT и он сам там по идее преобразует все куда надо если надо - если пишите R8 то и запишет R8 если конечно вы его в какое надо поле положите, обратно выдаёт наверное унифицированный тип - или строка или плавающая точка 2) нет, разрядности не имеет к этому отношения, R8 это C++ double, R4 это C++ float
1
|
|
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|||||||||||
| 30.03.2019, 20:03 | |||||||||||
|
Я сдаюсь, пытаюсь теперь записать данные в екель, берут тот же микрософтовский пример, он конечно же работает, но записывает в ексель числа VT_I4, а мне нужно чтобы записывался тектовый формат, то есть BSTR, вот кусочек работающего кода:
Причем методом тыка мне как то удалось записать именно в текстовом формате, вроде бы я обьявил массив, как BSTR, что то типа:
(((
0
|
|||||||||||
|
Модератор
3406 / 2177 / 354
Регистрация: 13.01.2012
Сообщений: 8,444
|
|
| 31.03.2019, 06:57 | |
|
Optimus11, ввести цифру как текст даже руками бывает не просто) если это не принципиально - вводите ‘001
0
|
|
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||||||
| 31.03.2019, 08:09 | ||||||
|
Бывает же такое, открыл с утра Ваше сообщение и сразу вспомнил, что я делал
:
0
|
||||||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|||||||||||
| 02.04.2019, 20:40 | |||||||||||
|
Позвольте еще один вопрос с участием все той же замечательной autowrap функцией:
Но, когда я пытаюсь применить тот же код для получения имени рабочей книги, то есть вот так:
То есть получается метод или свойство Name для или Activesheets находится, а для Workbook нет ? Добавлено через 21 минуту Все разобрался - ActiveWorkBook!
0
|
|||||||||||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||||||||||||||||||||||||||
| 05.04.2019, 19:47 | ||||||||||||||||||||||||||
|
Не могу понять, вот есть предположим 10 открытых файла из которых предположим нужно из ячейки "A1" считать данные.
Понятно, как считать данные из активного на данный момент файла и активного в нем листа, через autowrap:
0
|
||||||||||||||||||||||||||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
|
| 07.04.2019, 20:14 | |
|
Для этого есть метод Activate.
0
|
|
| 07.04.2019, 20:14 | |
|
Помогаю со студенческими работами здесь
35
Excel: создать новый массив по возрастанию элементов выделенного диапазона рабочей таблицы импорт выделенного диапазона Экспорт-импорт данных Excel-Access-Excel Обработка Excel и импорт из Excel в Access Excel -> Access -> Excel, импорт - экспорт Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|