|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
|
Опции темы | Поиск в этой теме |
22.09.2009, 19:14 | #1 |
минимакс
Участник клуба
Регистрация: 11.06.2008
Сообщений: 1,143
|
Код рабочий, но случайным образом Эксель глючит при сохранении. Где ошибка7
Вот код процедуры - рабочий.
Задача - есть файл определенной структуры - в одном столбце - название. В соседнем подряд без пустых ячеек - содержимое этого названия. Пример ЧП Матроскин кафе Буренка ферма Дядя Шарик магазин Умелые руки Задача из одного большого списка в экселе сделать 1 000 маленьких файлов по названию стуктуры типа "ЧП Матроскин" ошибка в том, что произвольно Эксель неожиданно при сохранении файла дает ему имя EFTR56000019.xls вместо желательного "ЧП Матроскин". Файлов много и каждый раз руками ловить и переименовывать тяжко. Где я ошибся. Я не большой знаток макросов. ПОловина кода - переделки записей макрокоманд. Ну и кое-где книги. Почему так получается при сохранении? Утечка памяти? или Эксель не успевает сохранить, а уже идет команда закрытия???? Код приведен полностью, кроме данным на ЛИСТ1. Там размещены только начальные адреса ячеек откуда плясать и пути и названия книг для открытия. Спасибо за помощь.
и это пройдет...
|
22.09.2009, 19:15 | #2 |
минимакс
Участник клуба
Регистрация: 11.06.2008
Сообщений: 1,143
|
Код:
и это пройдет...
Последний раз редактировалось grenles; 22.09.2009 в 19:18. |
22.09.2009, 19:32 | #3 | |
Программист VBA
СуперМодератор
Регистрация: 13.07.2008
Сообщений: 6,856
|
Много буков...
На будущее: вместо Код:
Код:
По теме: Рекомендую перед проблемной строкой кода поставить Код:
Цитата:
Возможна нехватка ресурсов - при работе с сотнями книг макросы порой зависают. Я в таких случаях (редко, но бывает - к примеру, когда программно создаёшь тысячи листов или книг) просто оптимизирую макрос путем переписывания его "с нуля" (ищу способ не создавать так много объектов) Хотите получить более подробный ответ - прикрепите к сообщению проблемный файл. |
|
22.09.2009, 20:37 | #4 |
минимакс
Участник клуба
Регистрация: 11.06.2008
Сообщений: 1,143
|
ага, спасибо, понял. Где-то я так и думал про ресурсы.
Файл дать не могу, так как это хоть и не большая секретность, но слегка не распространяемая информация. А единственный выход вижу выгружать партиями, допустим по 50 наименований... щас буду проводить экспенимент и учту ваши пожелания. Код выложу.
и это пройдет...
|
22.09.2009, 21:19 | #5 |
Участник клуба
Регистрация: 10.08.2009
Сообщений: 1,796
|
Здравствуйте grenles.
"про ресурсы" действительно стоит подумать, и один из самых эффективных способов это директива: Option Explicit Она заставит Вас объявлять переменные перед использованием, а систему выделять переменным только определенное кол-во памяти. Сейчас в коде не декларируется ни одна переменная, а применяется достаточно много. Тип Variant не самым лучшим образом обращается с памятью, тип переменных лучше указывать явно. В свете сказанного EducatedFool выше, рекомендую в код внести подобные изменения: Код:
|
22.09.2009, 21:59 | #6 |
минимакс
Участник клуба
Регистрация: 11.06.2008
Сообщений: 1,143
|
спасибо, понял
и это пройдет...
|
22.09.2009, 22:20 | #7 |
минимакс
Участник клуба
Регистрация: 11.06.2008
Сообщений: 1,143
|
кстати. я тут просто случайно попался на такой вещи - на диске С кончилось место и у меня закрались смутные подозрения что мой глюк связан с временными файлами экселя, которые просто некуда писать.
А все из-за каспера, он мне логов напилил на 9 гигов, я просто офигел!!!!
и это пройдет...
|
22.09.2009, 23:34 | #8 |
минимакс
Участник клуба
Регистрация: 11.06.2008
Сообщений: 1,143
|
100% у Экселя кончается память!!! Пишет "out of memory"
Помогите понять, где она "утекает" и что изменить в коде?
и это пройдет...
|
23.09.2009, 00:12 | #9 |
минимакс
Участник клуба
Регистрация: 11.06.2008
Сообщений: 1,143
|
Прикольно... вынес объявления переменных за процедуру
Private Sub CommandButton1_Click() - Эксель стал есть память меньше. но все равно она стала расти не в геометрической прогрессии, а в арифметической. Ищу решение дальше.
и это пройдет...
|
23.09.2009, 01:08 | #10 |
минимакс
Участник клуба
Регистрация: 11.06.2008
Сообщений: 1,143
|
Код:
и это пройдет...
Последний раз редактировалось grenles; 23.09.2009 в 01:26. |
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Макрос при сохранении | Полина Л. | Помощь студентам | 0 | 14.09.2009 16:30 |
[Pascal] вывод элементов из файла случайным образом | Рамик | Помощь студентам | 4 | 28.05.2009 17:18 |
Как вывести на экран двумерный массив случайным образом? | Stager | Общие вопросы C/C++ | 5 | 07.01.2009 20:53 |
Машина случайным образом генерирует натуральные числа в промежутке [0, 1, 2, … 100] | JustinTI | Помощь студентам | 4 | 21.12.2008 14:31 |
Машина случайным образом генерирует натуральные числа в промежутке [0, 1, 2, … 10] до тех пор, пока не 0 | JustinTI | Помощь студентам | 3 | 21.12.2008 14:31 |