Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
14 / 0 / 0
Регистрация: 06.12.2013
Сообщений: 2

Ускорение работы макроса (преобразование данных к нужному формату)

06.12.2013, 15:54. Показов 1513. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
в программировании на VBA недавно, а поэтому подозреваю, что подход к написанию кода во многом нубский. Для своей задачи (преобразование данных к нужному формату) сделал код, но он очень долго работает - порядка 3-4 часов на 200 000 данных, а мне нужно использовать миллионы
В общем большая просьба указать на факты неэффективного кода и помочь с его оптимизацией по времени.
Буду чрезвычайно благодарен.

Код во вложении
cod.zip
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.12.2013, 15:54
Ответы с готовыми решениями:

Ускорение работы макроса
Добрый день всем!!! Прошу помочь с нижеприведенным макросом на предмет ускорения его работы.Расчет делает минут 30-40 для 1500...

Ускорение макроса
Всем привет. У меня есть огромный макрос делающий динамические отчеты, т.е. есть база, он ее открывает, немного изменяет под себя, делает...

Написание макроса для совместной работы базы данных, накладных и ведомостей
Уважаемые форумчане! Прошу Вашей помощи в решении следующей задачи. Есть 5 таблиц: - накладная - база данных ...

5
3218 / 967 / 223
Регистрация: 29.05.2010
Сообщений: 2,087
06.12.2013, 16:31
Без примера данных код смотреть никакого смысла.
0
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
06.12.2013, 17:14
Последнюю строку можно быстро определить иначе, незачем перебирать в цикле все ячейки.
Например:

Visual Basic
1
2
3
4
With ActiveSheet
If .FilterMode Then .ShowAllData
iLastRow = .Cells(.Rows.Count, 1).End(xlUp).Row
End With
Все активейты и селекты убрать - они не нужны, пишите иначе.
И вообще если не анализируете форматы - работайте не с ячейками, а с данными через массив.
Думаю раз так в 50 скорость можно увеличить, а если разобраться с алгоритмом - то и быстрее можно сделать.

Но разбираться/делать без файла - это для мазохистов... Или совсем скучающих.
1
14 / 0 / 0
Регистрация: 06.12.2013
Сообщений: 2
06.12.2013, 18:25  [ТС]
Цитата Сообщение от toiai Посмотреть сообщение
Без примера данных код смотреть никакого смысла.
прикладываю вариант файла "resourse". второй файл "преобразователь" пустой, заполняется как раз данными из файла resourse
resourse_test.zip

писал код активно используя инструмент записи макросов, а отсюда огромное количество активейтов и селектов. как можно перейти к равнозначной конструкции? полностью указывать путь до ячейки? или используя with?
0
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
06.12.2013, 18:41
Ну у Вас ведь в середине кода есть куски без этих селектов!
Вот так и делайте.

Например

Visual Basic
1
2
    Columns("H:H").Select
    Selection.ClearContents
легко меняется на

Visual Basic
1
Columns("H:H").ClearContents
И с with конечно удобнее, если к одной ячейке нужно несколько раз обращаться.

И зачем там постоянно Calculate? Или Вы дальнейшие шаги ведь основываете на посчитанных результатах?
Ну или можно пересчитать только определённую область, а не всё.

Ну а формулы сами в конце разберутся.

Но я бы делал на массивах, без формул, раз уж там в перспективе сотни тысяч строк.
0
3218 / 967 / 223
Регистрация: 29.05.2010
Сообщений: 2,087
06.12.2013, 21:24
Ну вот пример кода на 1 листе:
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
24
25
26
27
28
29
30
31
32
33
Sub Преобразовать()
'
' Макрос1 Макрос
'
    Dim beg_hour As Double
    Dim end_hour As Double
    Dim WbRs As Workbook
    IstFile = "resourse_test.xlsx"
    Set WbRs = Workbooks(IstFile)
    
    a = AccelerateExcel()
  
    'таймфрейм
    tf = Workbooks("преобразователь.xlsm").Worksheets("параметры").Cells(2, 2)
    'подготавливаем 11-12____ЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖЖ
    WbRs.Sheets("11-12").Activate
    With Range(Cells(1, 3), Cells(ActiveSheet.UsedRange.Rows.Count, 6))
        .Replace What:=".", Replacement:=","
        'из-за косяков ЕКСЕЛЯ делаем финт ушами и приводим к нужным значениям
        .Value = .Value / 100000
    End With
    
    With Columns("C:C")
        'вставляем столбец
        .Insert Shift:=xlToRight, CopyOrigin:=xlFormatFromLeftOrAbove
        .NumberFormat = "dd/mm/yy h:mm;@"
        .ColumnWidth = 15
        'заполняем его данными по дате
        .Formula = "=DATEVALUE($A1)+TIMEVALUE($B1)"
        'превращаем просто в числа
        .Value = .Value
    End With
'......
Проверь работу этого кода и далее сделай тоже самое с другими листами источника, думаю результат будет заметно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.12.2013, 21:24
Помогаю со студенческими работами здесь

Ускорение макроса удаления ячеек
Добрый вечер! Очень нужна помощь. Подскажите,как ускорить макрос, который удаляет все неокрашенные ячейки из диапазона: Dim c As Range ...

Преобразование входящих текстовых данных к формату "время"
Всем здравствуйте, подскажите пожалуйста, как можно преобразовать данные к формату "Время" типа: длинный формат времени 00:00:00...

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

Преобразование к формату bmp
Пишу программу по стеганографии. Будет предусмотрена работа с разными форматами (bmp, jpeg, png, gif). Рассматриваю вариант преобразований...

Небезопасный код. Битовое чтение файла и преобразование к определенному формату
Доброго времени суток. Решаю задачу битового чтения файла и преобразование к определенному формату. Реализовал следующим образом ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru