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

Работа с большими файлами Excel

06.04.2012, 12:07. Показов 12650. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Имеется большой файл, сохранённый в ".xlsb", его размер 30Мб (вроде бы не так уж и велик), много страниц, формул и т.д.
При добавлении строки или (иногда) при сохранении пишет что недостаточно системных ресурсов (ОЗУ 3Гб), поискав нашёл пути решения этой проблемы - разбиение на несколько файлов (такой вариант не подходит) и добавление БД, по этой теме мне не удалось найти достаточно информации, т.к. Excel таблица в своём роде тоже БД и по запросу в google ничего толкового я не нашёл. Вопрос - как? и стоит ли игра свечь?

P.S.: Разного рода оптимизации существующего файла уже проводились. + Не исключено что есть другие пути решения проблемы.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.04.2012, 12:07
Ответы с готовыми решениями:

Работа с файлами Excel
какой процедурой выплняется сборка информации с эксель файлов? Именуйте темы осмысленно. Название темы должно максимально полно...

VBA работа с файлами Excel
Здравствуйте! Вопрос в следующем: Как реализовать чтение и запись данных из другой книги? Т.е. имеется форма(находится в одном файле),...

Работа с несколькими Файлами Excel
Привет всем. Задача такая, нужно заливать данные, вводимые в форме, в разные файлы Excel. Например нужно в файл1.лист2.ячейка(1,3) залить...

12
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
Цитата Сообщение от Sl12 Посмотреть сообщение
могу ли я создавать и работать БД Access без самого Access и можно ли использовать mySQL например или что-то бесплатное?
Теоретически вы можете работать с БД Access, но работа с БД без СУБД - это для особых ценителей.

Уверен, что и с mySQL не возникнет никаких проблем.
1
 Аватар для mc-black
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
Цитата Сообщение от mc-black Посмотреть сообщение
Трансформировать это в базу данных для меня пока не оправдано (высокие трудозатраты).
А потом трудозатраты снизятся? Вы же понимаете, что рано или поздно ваша "база" отбросит копыта и все равно придется переходить на БД.
0
7 / 7 / 0
Регистрация: 25.11.2010
Сообщений: 38
06.04.2012, 15:02  [ТС]
Цитата Сообщение от mc-black Посмотреть сообщение
Регулярно работаю с большими файлами, размер "базы" уже 39Mb в формате xls, оптимизации пока не требуется и памяти хватает (1Gb), листов в книге порядка 10-15. Единственный недостаток сейчас - время сохранения увеличилось, но в пределах допустимого. Трансформировать это в базу данных для меня пока не оправдано (высокие трудозатраты).

Кстати про оптимизацию. Я бы порекомендовал в файле полностью избавиться от внешних ссылок на другие книги Excel, т.к. при любом пересчете листа они в фоновом режме все-таки открываются, а это требует дополнительных ресурсов. И от связей между отдельными листами книги тоже можно избавиться, при помощи макросов, макросами же можно заменить "тяжелые" для вычислений формулы. Плюс не лениться и как-то систематизировать форматирование таблиц, т.к. загаживание листов беститтемными разношерстными форматами может сильно утяжелить книгу.
Писал же что оптимизация уже проведена, однако проблемы это не решило, в формате xls (2003) файл занимал около 90Мб, а то и больше.

Цитата Сообщение от Gibboustooth Посмотреть сообщение
А потом трудозатраты снизятся? Вы же понимаете, что рано или поздно ваша "база" отбросит копыта и все равно придется переходить на БД.
Настал видимо тот момент (мой случай), посмотрим что получится.
0
 Аватар для mc-black
2786 / 718 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
06.04.2012, 18:06
А потом трудозатраты снизятся? Вы же понимаете, что рано или поздно ваша "база" отбросит копыта и все равно придется переходить на БД.
Уже давно бы отбросила! Но я базу обнуляю каждый год, т.е. у меня инфа бъется по годам (а больше и не надо). Плюс у меня есть большой запас на оптимизацию - я могу разделить исходные данные и отчетные формы на 2 книги минимум.

Если б я развел фигни на 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
Цитата Сообщение от Sl12 Посмотреть сообщение
Для меня всё что надо сделать - это таблица, где ячейки, в которой сейчас есть формулы, просто значение связано со значением в БД, ну и при изменении пользователем значения в таблице изменяется значение и в БД.
Это не так просто, как вам представляется. Вы когда-нибудь работали с базами данных?
0
7 / 7 / 0
Регистрация: 25.11.2010
Сообщений: 38
07.04.2012, 12:53  [ТС]
Цитата Сообщение от Gibboustooth Посмотреть сообщение
Это не так просто, как вам представляется. Вы когда-нибудь работали с базами данных?
Да, давненько правда было, писал пару сайтов на ASP.NET, программы на C# c БД и несколько Java приложений, знаю что не просто, в 2 этапа - собрать всё в БД и потом связать значения с ячейками. Посмотрим что получится.
0
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18033 / 7736 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
12.04.2012, 12:57
Цитата Сообщение от Gibboustooth Посмотреть сообщение
При организации базы данных советую обратиться к т.н. "нормальным формам"
Нашел внятное описание с примерами.
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 через
Visual Basic
1
oConn.Execute strSQL
, а не через
Visual Basic
1
rs.Open strSQL, oConn
). Так оно мне кажется более правильным.

Подводные камни будут в том, что вам надо будет контролировать действия пользователя на листе Excel. Например, нужно будет запрерить добавлять или удалать столбцы, добавлять данные в любое место листа, а не только в первой свободной строчке. Также вам придется выделить один из столбцов под ID записи в таблице (ее уникальный ключ).
Проверку вводимых данных и выпадающие списки можно, в принципе реализовать с помощью средств самого Excel (Данные -> Проверка данных). Придется, конечно, со списками немного позаморачиваться, но там все решаемо.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.04.2012, 13:54
Помогаю со студенческими работами здесь

Работа в Excel с текстовыми файлами
Подскажите пожалуйста как можно при нажатии на кнопку формы в excel запустить на распечатку текстовый файл или скажем файл Word

Работа с большими файлами
Как редактировать большие файлы? Если текстовый редакторы виснут, а нужно удалить некоторые строки из файла по регулярке.

Работа с большими файлами
Подскажите как обрабатывать большие файлы построчно и максимально быстро

Работа с большими файлами
Как в c/c++ работать с большими файлами? А точнее нужно открывать файлы размером больше 10 ГБ и работать с ними.

Работа с большими файлами
Доброго времени суток, необходима помощь Задача: Имеется большое количество (около 1000) .txt-файлов в размере от 1 до 300МБ, в которых...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
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 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru