|
7 / 7 / 0
Регистрация: 25.11.2010
Сообщений: 38
|
|
Работа с большими файлами Excel06.04.2012, 12:07. Показов 12650. Ответов 12
Метки нет (Все метки)
Доброго времени суток. Имеется большой файл, сохранённый в ".xlsb", его размер 30Мб (вроде бы не так уж и велик), много страниц, формул и т.д.
При добавлении строки или (иногда) при сохранении пишет что недостаточно системных ресурсов (ОЗУ 3Гб), поискав нашёл пути решения этой проблемы - разбиение на несколько файлов (такой вариант не подходит) и добавление БД, по этой теме мне не удалось найти достаточно информации, т.к. Excel таблица в своём роде тоже БД и по запросу в google ничего толкового я не нашёл. Вопрос - как? и стоит ли игра свечь? P.S.: Разного рода оптимизации существующего файла уже проводились. + Не исключено что есть другие пути решения проблемы.
0
|
|
| 06.04.2012, 12:07 | |
|
Ответы с готовыми решениями:
12
Работа с файлами Excel VBA работа с файлами Excel Работа с несколькими Файлами Excel |
|
735 / 203 / 11
Регистрация: 23.06.2011
Сообщений: 440
|
|
| 06.04.2012, 13:28 | |
Сообщение было отмечено как решение
Решение
Да, безусловно стоит. Excel не предназначен для работы с большими объемами информации.
В первую оченедь, вам надо организовать хранение уже имеющихся данных. Для начала вполне подойдет база Access, так как ее проще освоить, хотя по опыту работы с ним и с БД Oracle - особой разницы для Excel нет, он с обемими базами работает одинаково хорошо. При организации базы данных советую обратиться к т.н. "нормальным формам" (тут Гугл вам в помощь). В принципе, рано или поздно вы сами к этому придете, потому что иначе с базой данных очень тяжело работать. Но это произойдет через пару полных перекраиваний структуры с нуля, так что лучше учиться на чужих ошибках Следующий шаг - настроить получение данных. В принипе, Access уже имеет табличное представление, формы и отчеты, хотя его функционал в этом плане, конечно, значительно хуже, чем у Excel. В любом случае, вам придется освоить язык запросов к базам данных SQL, потому что без него дальше никуда. Access умеет строить простые запросы в графическом виде, но как только вам потребуется что-то более сложное - придется все делать руками. Учтите, что SQL-редактор Access, настолько убог, что Блокнот по сравнению с ним просто межгалактический крейсер. Если у вас получиться ограничиться Access - просто замечательно. Если все-таки необходим Excel - придется настраивать обмен данных. В Excel есть 2 встроенных способа получения данных из БД - это простая таблица и сводная таблица, связанные с определенным подключением. Первую можно создать с листа "Данные", вторую - с листа "Вставка". Сводная таблица - вещь во многих отношениях почти незаменимая, советую с ней познакомиться. Ну и следующий шаг - передача данных из Excel в БД. Тут вам, скорее всего, понадобятся UserForms, функционал и внешний вид которых оставляют желать, но большинство задач с их помощью все-таки реализуема. Здесь есть небольшой пример кода для работы с БД Access.
3
|
|
|
7 / 7 / 0
Регистрация: 25.11.2010
Сообщений: 38
|
|
| 06.04.2012, 13:58 [ТС] | |
|
Спасибо за развёрнутый ответ, с SQL знаком, писал на C#, правда давно, с Access никогда не работал, да и не установлен он у меня (а покупать не хочется), БД от Oracle, как Вы понимаете, в таком случае точно не подходит, следовательно возникает вопрос - могу ли я создавать и работать БД Access без самого Access и можно ли использовать mySQL например или что-то бесплатное?
0
|
|
|
735 / 203 / 11
Регистрация: 23.06.2011
Сообщений: 440
|
||
| 06.04.2012, 14:10 | ||
|
Уверен, что и с mySQL не возникнет никаких проблем.
1
|
||
|
2786 / 718 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
|
|
| 06.04.2012, 14:10 | |
|
Регулярно работаю с большими файлами, размер "базы" уже 39Mb в формате xls, оптимизации пока не требуется и памяти хватает (1Gb), листов в книге порядка 10-15. Единственный недостаток сейчас - время сохранения увеличилось, но в пределах допустимого. Трансформировать это в базу данных для меня пока не оправдано (высокие трудозатраты).
Кстати про оптимизацию. Я бы порекомендовал в файле полностью избавиться от внешних ссылок на другие книги Excel, т.к. при любом пересчете листа они в фоновом режме все-таки открываются, а это требует дополнительных ресурсов. И от связей между отдельными листами книги тоже можно избавиться, при помощи макросов, макросами же можно заменить "тяжелые" для вычислений формулы. Плюс не лениться и как-то систематизировать форматирование таблиц, т.к. загаживание листов беститтемными разношерстными форматами может сильно утяжелить книгу.
0
|
|
|
735 / 203 / 11
Регистрация: 23.06.2011
Сообщений: 440
|
||
| 06.04.2012, 14:16 | ||
Вы же понимаете, что рано или поздно ваша "база" отбросит копыта и все равно придется переходить на БД.
0
|
||
|
7 / 7 / 0
Регистрация: 25.11.2010
Сообщений: 38
|
|||
| 06.04.2012, 15:02 [ТС] | |||
|
0
|
|||
|
2786 / 718 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
|
||
| 06.04.2012, 18:06 | ||
Если б я развел фигни на 50-90 Mb, я бы конечно подумал о БД, особенно мне нравится идея не с одной базой Access, а связка: БД в Assess, а интерфейс к ней - ввод и обработка данных, вывод отчетов - в Excel, как в первом ответе. Но это надо немного заморочиться и сделать!
0
|
||
|
7 / 7 / 0
Регистрация: 25.11.2010
Сообщений: 38
|
|
| 06.04.2012, 19:00 [ТС] | |
|
Для меня всё что надо сделать - это таблица, где ячейки, в которой сейчас есть формулы, просто значение связано со значением в БД, ну и при изменении пользователем значения в таблице изменяется значение и в БД.
0
|
|
|
735 / 203 / 11
Регистрация: 23.06.2011
Сообщений: 440
|
||
| 06.04.2012, 19:40 | ||
|
0
|
||
|
7 / 7 / 0
Регистрация: 25.11.2010
Сообщений: 38
|
||
| 07.04.2012, 12:53 [ТС] | ||
|
0
|
||
|
|
||
| 12.04.2012, 12:57 | ||
|
3-я форма избавит в будущем от головной боли. Итак, mySQL установлен и настроен. А как правильно оформить VBA-кодом запрос к БД mySQL? Добавлено через 32 минуты Вот здесь дан оптимальный код? Не будет подводных камней при работе с такой базой на удаленном серваке? Я так понял для экспериментов нужно кроме установки серв. части на localhost, еще и устанавливать некий драйвер связи MySQL Connector/ODBC 5.1 Сайт генерации различных вариантов запросов подключения к БД SQL
0
|
||
|
735 / 203 / 11
Регистрация: 23.06.2011
Сообщений: 440
|
|||||||||||
| 13.04.2012, 13:54 | |||||||||||
|
Таблица в примере кривая - не в 3-й нормальной форме, потому что у одной книги может быть несколько авторов.
А, код нормальный (хотя я предпочитаю выполнять запросы INSERT и UPDATE через
Подводные камни будут в том, что вам надо будет контролировать действия пользователя на листе Excel. Например, нужно будет запрерить добавлять или удалать столбцы, добавлять данные в любое место листа, а не только в первой свободной строчке. Также вам придется выделить один из столбцов под ID записи в таблице (ее уникальный ключ). Проверку вводимых данных и выпадающие списки можно, в принципе реализовать с помощью средств самого Excel (Данные -> Проверка данных). Придется, конечно, со списками немного позаморачиваться, но там все решаемо.
1
|
|||||||||||
| 13.04.2012, 13:54 | |
|
Помогаю со студенческими работами здесь
13
Работа в Excel с текстовыми файлами Работа с большими файлами Работа с большими файлами Работа с большими файлами Работа с большими файлами Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536
Одним из. . .
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|