Правильная конкатенация18.04.2023, 02:34. Показов 6358. Ответов 117
Метки нет (Все метки)
На другом форуме видел такой вариант конкатенации большого массива и он мне очень понравился, поскольку скорость близкая к join. На сколько я знаю тип String это структура содержащая в себе массив символов и еслиб у нас был доступ к этому массиву и возможность делать что-то вроде redim preserve.. В общем, можно ли как-то улучшить алгоритм, чтоб закасматить окончательно етот join? )
0
|
||
| 18.04.2023, 02:34 | |
|
Ответы с готовыми решениями:
117
Из символов одного текста строковых функций о операций конкатенация получить другой текст Правильная обработка ошибок конкатенация строки |
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 12.09.2023, 17:09 | |
|
0
|
|
|
Модератор
|
||||||
| 12.09.2023, 20:02 | ||||||
Сообщение было отмечено testuser2 как решение
Решение
Работать непосредственно с символами можно без проблем замапив SAFEARRAY дескриптор на данные:
1
|
||||||
| 13.09.2023, 02:34 [ТС] | ||
|
The trick, Спасибо за более подробный разбор структуры SafeArray, но еще можно добавить, что надо всегда запоминать прежние указатели, и возвращать потом их на место (для vba это критичный момент)
Добавлено через 13 минут
0
|
||
| 13.09.2023, 14:22 [ТС] | ||||||
|
Все, понял как это работает, благодаря коду Анатолия. Получается, что VarPtr(ArrPtr) в случае с массивом дает нам адрес, места где находится указатель на структуру (SAFEARRAY1D). Поменяв этот указатель, мы легко можем залинковать переменнюу массива на свою структуру (как в данном случае), или на структуру другого массива, фактичеки сделав указатель-клон другого массива, который не будет сбиваться, даже если сделать redim preserve. На vba так будет рабоать без вылета, нужно только вернуть прежнее состояние массива (обнулить указатель) в конце.
0
|
||||||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 13.09.2023, 16:07 | |
|
testuser2, нифигасебе ты заморочился)
0
|
|
| 13.09.2023, 17:48 [ТС] | ||||||
|
HackerVlad, еще бы с устройтвом 2мерного массива разобраться (в Екселе 2 мерные часто используются), и можеть сделать, какой-нибудь join для 2мерного массива..
Добавлено через 1 час 17 минут x64 vba-совместимый вариант Кликните здесь для просмотра всего текста
0
|
||||||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
||
| 13.09.2023, 19:33 | ||
|
Добавлено через 59 секунд да и вместо двухмерного массива мне проще массив структуры использовать) с нужными атрибутами)))
0
|
||
|
Модератор
|
|||
| 13.09.2023, 20:17 | |||
|
0
|
|||
| 14.09.2023, 18:06 [ТС] | |||||||
|
С SafeArray разных размерностей и типов, более менее освоился. У всех массивов данные в сущности являются единым блоком, который можно представить как вектор (1d массив). Если это матрица, то элементы располагаются постолбечно. Прямой доступ к данным вариантного 2мерного массива:
0
|
|||||||
| 16.09.2023, 04:50 [ТС] | ||
|
Вот, к слову, интересная страничка, пока не уловил, в чем там суть. Кто поймет объясните в общих чертах если не трудно.
0
|
||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
||
| 16.09.2023, 12:13 | ||
|
0
|
||
| 16.09.2023, 13:01 [ТС] | |
|
У меня по его тестам, api функция, оказалась значительно быстрее, чем его реализация, но кто его знает, может было бы по другому, на x64 c последними обновлениями и включенным "защитником". У него без CopyMemory как-то работает, почему-то используется variant..
0
|
|
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 16.09.2023, 14:27 | |
|
testuser2, да не обращай внимания на этот код вообще
0
|
|
| 16.09.2023, 15:17 [ТС] | |||||||||||||||||
0
|
|||||||||||||||||
|
Модератор
|
|
| 16.09.2023, 15:22 | |
|
Такое вообще проще сделать через SAFEARRAY. Сделать Long массив размером от 0 до 536870912 и адресовать всю память. Для Byte и Integer просто битовыми масками выделять нужную часть. Для 64 бит так уже не получится придется динамически подгонять размер или указатель т.к. там 64 битная адресация.
1
|
|
| 16.09.2023, 15:59 [ТС] | ||
|
0
|
||
|
Модератор
|
|||
| 16.09.2023, 16:05 | |||
|
1
|
|||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 16.09.2023, 16:07 | |
|
0
|
|
| 16.09.2023, 16:07 | |
|
конкатенация строк в excel через vba Конкатенация и последующее копирование уникальных строк по условию Добавление записей массива из одной книги на лист другой + возможная конкатенация Из символов одного текста с помощью стоковых функций о операция конкатенация получить другой текст Конкатенация Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS
Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
|
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи.
Через несколько переработок от PHP кода к C89 (надеюсь, 89).
Но довольно запутанно получилось. Код для Linux.
Но если убрать time и то, что с ним. . .
|
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки
Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
|
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы
Всем привет! Хочу поделиться свежим (и довольно. . .
|
|
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
|
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения:
- добавлена многоязычность
- добавлено снятие скриншотов
- добавлено поддержание бафов хождения по воде (для жреца, дк и шамана)
- и так, по. . .
|
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу)))
Критические ошибки, мешающие компиляции и. . .
|
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата)
Этот документ предназначен для того, чтобы новый чат Claude мог продолжить
работу без необходимости заново разбираться в. . .
|