Использование Python при выгрузке в Excel с формулами

05.04.24

Интеграция - Загрузка и выгрузка в Excel

Иногда встает задача, что нужно выгрузить какую-то таблицу с формулами, чтобы дальше пользователь мог играться с данными. И есть простой путь использовать com-объект Excel, чтобы после выгрузки "активировать" формулы, но что делать, если нет windows машины ни на сервере, ни на клиенте.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
ПримерPythonВыгрузкаExcelСФормулами
.cf 83,14Kb
2 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

И тут приходит идея либо распаковать xlsx, и копаться во внутренностях формата, либо взять какой-то сторонний инструмент и использовать его.

В данной статье мы попробуем использовать python и его пакет openpyxl для решения данной задачи.

Нам потребуется:

1. установить python (https://www.python.org/)

2. установить пакет openpyxl (pip install openpyxl)

3. скрипт (reform.py), который при нахождении в ячейке знака "=" будет активировать формулу

from openpyxl import load_workbook
from sys import argv

script, inputFile, outputFile = argv

wookbook = load_workbook(inputFile)

for worksheetName in wookbook.sheetnames:
    worksheet = wookbook[worksheetName]
    for i in range(0, worksheet.max_row):
        for col in worksheet.iter_cols(1, worksheet.max_column):
            if str(col[i].value)[0] == '=':
                col[i].value = col[i].value

wookbook.save(outputFile)

Например, мы сформировали Табличный документ, где в ячейках прописали формулы, и сохранили его (input.xlsx), но при открытии для Excel это всего лишь текст

 

 

Чтобы текст в ячейке превратился в формулу, нужно запустить скрипт

python reform.py input.xlsx output.xlsx

после в файле output.xlsx все формулы будут работать

 

 

Тем самым мы решили проблемы по выгрузке файла Excel с формулами без Windows машин.

Пакет openpyxl очень богат, и с его помощь можно, например, изменять формат ячейки (популярный пример это формат Даты, чтобы при отборе было дерево)

Нюансы при использовании:

1. использовать формулы в английском формате, не только ключевое слово, но и знаки разделители (например в русских формулах используется ";", в английских ",")

2. при windows окружении при использовании "ЗапуститьПриложение" использовать полный путь до python.exe. (при использовании Linux можно просто python или python3, проверяйте как он в вашей системе называется)

Пример реализован на платформе 1С:Предприятие 8.3 (8.3.22.2411).

Вступайте в нашу телеграмм-группу Инфостарт

excel python

См. также

Загрузка и выгрузка в Excel Маркетплейсы Программист Бухгалтер Пользователь 1С:Предприятие 8 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Бухгалтерский учет Управленческий учет Платные (руб)

Реальный помощник, с помощью которого Вы преобразуете необходимые документы для Wildberries, OZON, ЯндексМаркет, Мегамаркет, Aliexpress, Детский мир, Магнит Маркет (быв.МагнитЭкспресс), Лемана про, ЭНФАНТА (Акушерство), ЛаМода, Летуаль, Твой дом, Золотое Яблоко, Каспи в документы "Отчет комиссионера (агента) о продажах" и другие. Работает в 1С:БП 3.0, 1С:БП 3.0 КОРП, 1С:УТ 11, 1С:УНФ, 1С:ERP.

5490 руб.

12.08.2021    44843    553    71    

215

SALE! 15%

Загрузка и выгрузка в Excel Оптовая торговля Бухгалтер Пользователь 1С:Предприятие 8 1С:Бухгалтерия 2.0 1С:Бухгалтерия 3.0 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Комплексная автоматизация 1.х 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 10 1С:Управление торговлей 11 1С:Розница 2 1С:Розница 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Универсальная обработка для загрузки документов из Excel в 1С. Забудьте о ручном вводе: загружайте документы из Excel в 1С за секунды! Не требует указания параметров (номера колонок, номер первой строки таблицы и т.д.) и предварительной настройки. Просто выбираете файл эксель, документ 1С и нажимаете кнопку "Загрузить"

8000 руб.

09.11.2016    269723    1190    950    

1107

Загрузка и выгрузка в Excel Розничная торговля Логистика, склад и ТМЦ Ценообразование, анализ цен Прайсы Системный администратор Программист 1С:Предприятие 8 1С:Комплексная автоматизация 1.х 1С:Розница 2 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Управленческий учет Платные (руб)

Загрузка номенклатуры из файлов Excel (xls, xlsx, ods, csv, mxl) в УТ11, КА 2, ERP 2, Розница 2. Задействованы все возможности конфигурации - заполнение реквизитов номенклатуры, дополнительных реквизитов и сведений, характеристики, доп.реквизиты и сведения характеристик. Дополнительные обработки для расширения возможностей.

12444 руб.

29.10.2014    229979    739    528    

492

Загрузка и выгрузка в Excel Логистика, склад и ТМЦ Ценообразование, анализ цен Файловый обмен (TXT, XML, DBF), FTP Бухгалтер Пользователь 1С:Предприятие 8 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Эволюция не стоит на месте - новая удобная версия функциональной обработки для Вашего бизнеса! Что же Вы получаете? Удобный и интуитивно понятный интерфейс с 3-мя этапами работы. 2 режима - автоматический и ручной. Чтение XLSX, XLSM, CSV, XML/YML форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 12.12.2025, версия 9.3.1 - 10.6.1)

20740 руб.

20.11.2015    172416    426    396    

542

WEB-интеграция Загрузка и выгрузка в Excel Программист Пользователь 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Розничная и сетевая торговля (FMCG) Россия Платные (руб)

Расширение освободит вас от необходимости вручную обновлять товары в группах ВКонтакте. Достаточно задать правила один раз, и система автоматически синхронизирует ваш каталог. Вы сможете легко выбирать, какие товары публиковать, создавая гибкие критерии отбора. Например, можно добавить важные для покупателей параметры: цвет, размер или другие характеристики.

12200 руб.

29.08.2025    2030    6    0    

7
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. xlmel 05.04.24 12:00 Сейчас в теме
Таким образом Вы предлагаете каждому пользователю 1С в организации поставить python на компьютер, установить openpyxl и положить программу, так как заранее не известно понадобится или нет. Может проще сделать приложение на Flask (это не реклама Flask, можно взять любой фреймворк, просто с этим работал и были положительные результаты), опубликовать его на web-сервере и вызывать его стандартными HTTP-запросами. Мой опыт показывает, что предложенный вызов интерпретатора python занимает намного больше времени, чем http-запрос. Кроме того, используя разные роуты, можно подключить разные функции: и форматирование, и "оживление" формул и так далее.
2. Tahallus 441 05.04.24 12:12 Сейчас в теме
(1) Вроде я не писал что надо каждому пользователю ставить, можно поставить на сервере и все делать там, готовый результат передавать на клиент. Опять же это пример демонстрации подхода, а не законченное решение. Про вызывать напрямую или через http-запрос тоже вопрос реализации, стоит ли разрабатывать и поднимать Flask, http-запрос если тебе надо просто разослать например 100 прайсов один раз в день, цена ускорения допустим 1 минута, а затраты на поддержку всего этого стоят того, вопрос.
3. Eugeneer 925 06.04.24 10:22 Сейчас в теме
Большая проблема что сама платформа не имеет средств. И вообще в целом до сих пор нормально не работает с офисами...
Хотя за десятки лет 1С могла бы и свой офис сделать. И в том числе внутренние табличные документы развить нормально.
Спрос же есть!
4. kalyaka 1149 06.04.24 15:55 Сейчас в теме
Можно прочитать и напрямую из 1С, используя ПостроительDOM и xPath. Для этого необходимо:
1. распаковать xlsx (zip архив)
2. в файлах xml заменить строку "xmlns:=" на "xmlns:_=" - это нужно чтобы работал встроенный в платформу xPath
3. прочитать листы из файла "xl\workbook.xml" по выражению XPath = "//sheet"
4. прочитать нужный лист "xl\worksheets\sheet%1.xml"
5. вначале найти все "зашаренные формулы" по выражению XPath = "//f[@ref]", формула в узле "f", индекс в узле "si"
6. затем найти все формулы в нужной строке XPath = СтрШаблон("//row[@r=%1]", НомерСтроки). При этом если узел "f" пустой, то прочитать атрибут "si" и взять формулу из зашаренных ранее по индексу
5. leoxz 281 03.06.24 13:26 Сейчас в теме
Благодарю за статью, пригодилась.

Можно сразу перебирать листы и вместо:
for worksheetName in wookbook.sheetnames:
worksheet = wookbook[worksheetName]

Использовать
for worksheet in wookbook:

при windows окружении при использовании "ЗапуститьПриложение" использовать полный путь до python.exe
Проверяю на Windows машине - работает сразу Python. Скорее всего это зависит от настройки PATH и PYTHONPATH
Для отправки сообщения требуется регистрация/авторизация