Правильная конкатенация18.04.2023, 02:34. Показов 6049. Ответов 117
Метки нет (Все метки)
На другом форуме видел такой вариант конкатенации большого массива и он мне очень понравился, поскольку скорость близкая к join. На сколько я знаю тип String это структура содержащая в себе массив символов и еслиб у нас был доступ к этому массиву и возможность делать что-то вроде redim preserve.. В общем, можно ли как-то улучшить алгоритм, чтоб закасматить окончательно етот join? )
0
|
||
| 18.04.2023, 02:34 | |
|
Ответы с готовыми решениями:
117
Из символов одного текста строковых функций о операций конкатенация получить другой текст Правильная обработка ошибок конкатенация строки |
|
Испарился
1742 / 638 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 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
|
||||||
|
Испарился
1742 / 638 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 13.09.2023, 16:07 | |
|
testuser2, нифигасебе ты заморочился)
0
|
|
| 13.09.2023, 17:48 [ТС] | ||||||
|
HackerVlad, еще бы с устройтвом 2мерного массива разобраться (в Екселе 2 мерные часто используются), и можеть сделать, какой-нибудь join для 2мерного массива..
Добавлено через 1 час 17 минут x64 vba-совместимый вариант Кликните здесь для просмотра всего текста
0
|
||||||
|
Испарился
1742 / 638 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
||
| 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
|
||
|
Испарился
1742 / 638 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
||
| 16.09.2023, 12:13 | ||
|
0
|
||
| 16.09.2023, 13:01 [ТС] | |
|
У меня по его тестам, api функция, оказалась значительно быстрее, чем его реализация, но кто его знает, может было бы по другому, на x64 c последними обновлениями и включенным "защитником". У него без CopyMemory как-то работает, почему-то используется variant..
0
|
|
|
Испарился
1742 / 638 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 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
|
|||
|
Испарился
1742 / 638 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 16.09.2023, 16:07 | |
|
0
|
|
| 16.09.2023, 16:07 | |
|
Помогаю со студенческими работами здесь
60
конкатенация строк в excel через vba Конкатенация и последующее копирование уникальных строк по условию Добавление записей массива из одной книги на лист другой + возможная конкатенация Из символов одного текста с помощью стоковых функций о операция конкатенация получить другой текст Конкатенация Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
|
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2.
Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
|
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2.
Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом.
В. . .
|
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2.
Задача: отобразить спецтехнику, которая на данный момент находится в ремонте.
Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
|
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|