Внешняя компонента для загрузки файлов Excel 2007-2010 (OpenXML) в табличный документ 1С 8

19.09.12

Разработка - Разработка внешних компонент

Внешняя компонента для прямого чтения файла формата OpenXML (Excel 2007-2010) и загрузки рабочего листа в табличный документ "1С:Предприятие 8" с полным сохранением оформления.

Скачать файл

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

Наименование По подписке [?] Купить один файл
PTLoad_v1_0.zip
.zip 556,37Kb
149
149 Скачать (1 SM) Купить за 1 850 руб.

Как и большинство программистов 1С я часто сталкивался с необходимостью загрузки электронных таблиц в 1С. Была освоена и объектная модель Excel и технология ADO. Но каждый раз при написании обработок загрузки мне очень не хотелось в очередной раз использовать конструкции типа "Книга = Эксель.Workbooks.Open(...)", "ConnectionString="Provider=Microsoft..." и пр. Хотелось работать в виде последовательности "Открыл файл" - "Выбрал лист" - "Загрузил в таблицу 1С" - "Работаю с внутренней таблицей встроенными методами 1С как с исходным документом".

Также хотелось иметь инструмент для максимально подробного просмотра файлов Excel в 1С с полным оформлением (цвета заливки, текста, рамки, объединения и пр.).

Была разработана ВК для "1С:Предприятие 8", которая по сути работает по вышеуказанному принципу. Методы ВК:

ОткрытьТабличныйФайл(ИмяФайла) - открывает файл электронной таблицы Excel.

ПолучитьСписокЛистов() - возвращает в случае удачного завершения список значений с именами рабочих листов таблицы.

ЗагрузитьЛист(ТабличныйДокумент,ИмяЛиста) - загружает лист с именем "ИмяЛиста" в табличный документ полностью. Загружаются значения типа Число, Дата, Булево, Строка, а также сохраняется все оформление (рамки, шрифт, цвета заливки и текста, объединения, ширина столбцов и высота строк).

ЗагрузитьОбластьЛиста(ТабличныйДокумент,ИмяЛиста,[Строка1],
[Столбец1],[Строка2],[Столбец2]) - загружает прямоугольную область листа в соответствующую область табличного документа. Сохраняется все оформление области.

Ограничения:

  1. Читаются только файлы формата OpenXML (xlsx, xlsm).
  2. Файл не должен быть защищен паролем.
  3. Не читаются картинки, сводные таблицы, диаграммы. Только рабочие листы с данными.

Скачиваемый архив содержит:

внешнюю компоненту PTLoad.DLL, документацию по методам и свойствам, обработки для 8.1 и 8.2, демонстрирующие просмотр всех листов файла Excel.

См. также

Разработка внешних компонент POS терминал Рабочее место Розничная торговля Программист Пользователь Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Рестораны, кафе и фаст-фуд Реклама, PR и маркетинг Управленческий учет Платные (руб)

Медиадисплей покупателя может отображать текущую покупку на кассовом месте, показывать видеорекламу, баннеры, во время простоя разворачивать рекламу на весь экран. Экран можно использовать в качестве графического меню-борда в кафе и видеовывески. В качестве устройства отображения можно использовать Android-планшеты, смарт-телевизоры с Android, мониторы или проекторы под управлением Windows или Linux-компьютера. Linux-версия успешно запускается на одноплатных компьютерах Raspberri Pi и Orange Pi. Настраивается ЛЮБОЙ ДИЗАЙН экрана при помощи встроенного графического редактора! Решение можно масштабировать от одного экрана до тысяч экранов с централизованным управлением.

18000 руб.

30.05.2017    53877    9    69    

46

Разработка внешних компонент Телефония, SIP Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Внешняя компонента выполнена по технологии Native API для 1С 8.х, обеспечивает доступ к программным АТС Asterisk (FreePBX, Elastix) через AMI интерфейс. Через него можно управлять многими функциями Asterisk (определение номеров, перевод звонков, набор телефона и т. д.)

2400 руб.

04.05.2018    47115    123    66    

67

Разработка внешних компонент Программист Платформа 1С v8.3 Платформа 1C v8.2 Платные (руб)

Внешняя компонента, позволяющая посылать команды и получать ответы по GraphQL протоколу из 1С.Может быть использована при интеграции. В 1С работает на стороне "клиента".

4600 руб.

27.06.2023    3523    3    0    

5

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление торговлей 11 Платные (руб)

Внешняя компонента для конвертации PDF файлов в картинки без использования дополнительных программ. Работает на сервере и в тонком клиенте.

2400 руб.

25.06.2024    1042    2    4    

2

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Внешняя компонента в виде библиотеки (.dll файл), позволяющая посылать команды и получать ответы по протоколу WebSocket из 1С. Компонента работает только на стороне "клиента".

4440 руб.

22.06.2020    18315    18    33    

22

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Позволяет автоматизировать работу с картинками. С помощью компоненты можно измерять размер изображений, поворачивать их, наносить водяные знаки, конвертировать из одного формата в другой. Будет очень полезна для интернет-магазинов и всех, кому постоянно требуется работать с различными графическими форматами. Выполнена по технологии NativeAPI. Работает с форматами: jpg (jpeg), png, bmp, gif, tif

3600 руб.

02.09.2010    77406    72    257    

191

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 Платные (руб)

Внешняя компонента позволяет работать c TWAIN-совместимым оборудованием (сканерами, камерами) . Полностью совместима со стандартной TWAIN-компонентой из БСП и может применяться как ее замена без изменения вызовов, при этом может работать с 64-разрядной платформой, а так же имеет расширенную функциональность, например, сохранение результата непосредственно в PDF без использования сторонних утилит. Прекрасно работает на сервере, тонком клиенте и веб-клиенте (проверена работа в браузерах Google Chrome, Mozilla Firefox и Microsoft Internet Explorer).

3000 руб.

12.05.2020    28507    138    100    

91

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Бесплатно (free)

В статье описывается приложение-конструктор внешних компонент (native API). Конструктор упрощает процесс разработки за счет удобного добавления всех нужных функций и процедур в графическом режиме, с указанием их параметров и типов параметров. На выходе приложение генерирует готовый код на С++ и Rust и позволяет сразу приступить к реализации, без настройки API компоненты вручную.

04.12.2024    4385    kovalevdmv    26    

73
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Abadonna 3969 21.09.12 05:05 Сейчас в теме
(0) Вопрос простой, как грабли: Excel в системе должен быть установлен?
2. Anselm 35 21.09.12 11:56 Сейчас в теме
(1) Нет, Эксель не нужен. Файл напрямую читается.
3. CagoBHuK 33 21.09.12 13:00 Сейчас в теме
4. пользователь 21.09.12 21:57
Сообщение было скрыто модератором.
...
5. Angeros 24.09.12 05:15 Сейчас в теме
в 8.2 есть возможности чтения xlsx напрямую без посредников в виде компоненты... Вообще использования всяческих компонент это зло, часто без них никак не обойтись, но точно не в этом случае...
6. Anselm 35 25.09.12 13:02 Сейчас в теме
(5) подключение ВК ничем не хуже вызова Экселя или ADO. А OpenXML вообще можно разобрать везде, не только в 8.2
7. Angeros 26.09.12 03:59 Сейчас в теме
(6)Я с вами не соглашусь. ms поддерживает windows. 1с поддерживает свою программу. А что будет с вашей компонентой когда выйдет новый Windows или 1с ?! где гарантия что автор компоненты и далее будет поддерживать свой продукт.?

Вот у меня есть пример когда компонента чудесно работала на 77. а на 8.1 она уже не смогла работать в силу технических особенностей. Я написал автору компоненты он развел руками.

технические средства 1с не деградируют а в основном развиваются, тоже самое можно сказать и про встроенные возможности windows всегда на мой взгляд предпочтительней использовать стандартные средства обходясь без непонятных компонент. ADO Есть на всех современных windows, если это важно бизнесу Excel можно купить.
10. AlexO 136 11.10.12 11:07 Сейчас в теме
(7) Angeros,
технические средства 1с не деградируют

там просто некуда деградировать - настолько они примитивны.
(6) Anselm,
А OpenXML вообще можно разобрать везде

согласен. И, как будет сказано ниже, уже есть прекрасные наработки. Однако, вот это
(5) Angeros,
в 8.2 есть возможности чтения xlsx напрямую без посредников

минимум скрытие правды - ПРЯМЫХ ВОЗМОЖНОСТЕЙ В 1С НЕТ! (это также и к вопросу, как 1С "развивается").
Есть совпадение структур формата файлов внешнего приложения и функционала в 1С, а именно: с 2007 MS Office появились форматы файлов XLSX и DOCX соответственно.
Которые представляют собой всего лишь упакованные XML-файлы определенной структуры. А XML всегда был и остается доступным для редактирования в любом текстовом редакторе.
Отсюда - раз 1С умеет (кое-как с большими проблемами скорости чтения) работать с тектсовыми файлами, она априори сможет работать с новым форматом файлов MS Office. И рано или поздно должны были появиться хотя бы любительские разработки в этом направлении, что и произошло.
Есть уже встраиваемая обработка Душелова Чтение/Запись документа Excel 2007 без офиса, без ВК. (с примером для 7.7, 8.1 и 8.2 на управляемых формах), которая все это делает.
12. Angeros 11.10.12 17:22 Сейчас в теме
(10) AlexO, В целом согласен так и есть.
8. sergik_nsk 148 03.10.12 08:00 Сейчас в теме
согласен, ладно бы еще все было понятно и прозрачно, типа прочитал исходный код и спокоен, несмотря на это лень взяла верх и я скачал сей труд, читаю описалово - разработка перед регистрацией код активации хочет на сайте разработчика, даже регистрировать не стал, dll удалил, это типа скинь смс получишь много вкусного. Напишу сам - спокойней будет.
9. Anselm 35 03.10.12 09:59 Сейчас в теме
(8) прошу прощения за неточность в описании. Оно из версии для загрузки xls и ods взято, где действительно нужно код вводить. DLL в данной публикации код не требует.
11. AlexO 136 11.10.12 11:08 Сейчас в теме
(9) Anselm,
так вопрос - покой ляд разрабатывать внешнюю DLL ТОЛЬКО ДЛЯ ЧТЕНИЯ ФАЙЛОВ Office-2007??
13. vers139 53 09.04.13 17:45 Сейчас в теме
Подскажите, пожалуйста, как загрузит Ваша обработка код товара из Excel, если в ячейке значение 1, формат ячейки 0000 (пользователь видит 0001)?
14. Anselm 35 10.04.13 09:35 Сейчас в теме
(13) если в ячейке число (именно число, не преобразованное в строку), то независимо от формата в результирующий табличный документ будет загружено значение. То есть в Вашем примере будет загружено 1, и в ячейке будет стоять признак "СодержитЗначение". Если нужно загрузить число как строку, то в Excel нужно предварительно задать формат ячейки "Текстовый" и только потом вводить туда данные.
15. Cemen82 17.04.13 07:19 Сейчас в теме
ОткрытьТабличныйФайл(ИмяФайла) - открывает файл электронной таблицы Excel.

ПолучитьСписокЛистов() - возвращает в случае удачного завершения список значений с именами рабочих листов таблицы.

ЗагрузитьЛист(ТабличныйДокумент,ИмяЛиста) - загружает лист с именем "ИмяЛиста" в табличный документ полностью. Загружаются значения типа Число, Дата, Булево, Строка, а также сохраняется все оформление (рамки, шрифт, цвета заливки и текста, объединения, ширина столбцов и высота строк).

ЗагрузитьОбластьЛиста(ТабличныйДокумент,ИмяЛиста,[Строка1],
[Столбец1],[Строка2],[Столбец2]) - загружает прямоугольную область листа в соответствующую область табличного документа. Сохраняется все оформление области.
16. Vitaly18 20.06.18 17:05 Сейчас в теме
СписокЛистов = ВнешняяКомпонента.ПолучитьСписокЛистов(); - не возвращает список значений с именами рабочих листов таблицы - ..........закрывает 1с .
17. Vitaly18 28.06.18 10:31 Сейчас в теме
PTLоаd : Недоступно в ДЕМО-версии. Полная версия доступна по адресу www.perftab.com. <- большие файлы Excel не читает..
Оставьте свое сообщение