Из Word в табличный документ

18.08.21

Разработка - Универсальные функции

Быстро и просто: текст, списки, таблицы. Готовый код

Началось с того, что возникла задача сделать средствами mxl вывод документа, который предоставили в виде MS Word. Поскольку перекидывать в макет всё это было нудно, и была вероятность ошибиться, я слегка автоматизировал процесс. Именно слегка, т.к. всё равно ещё надо разбить на секции, сделать для таблиц вывод содержимого вместо пустых ячеек, подставить конкретику в нужных абзацах, итд. Но трудоёмкость стала в разы меньше.

Сразу подчёркиваю: это не совсем готовый механизм, который можно сразу давать пользователю (хотя для относительно простых документов прокатит), это инструмент для разработчика, которому надо сделать "как в Ворде", при этом ни Ворда, ни ОпенОфиса на доступных ПК может вообще не быть, или если нужна гибкость обработки, которую возня с шаблоном не даёт. Чтобы не морочиться с СОМ-действиями, или если эксплуатация будет вообще не на винде и СОМ там не светит.

Сам механизм использует СОМ, в режиме чтения вытаскивая из документа самое основное. Получающийся табличный документ единый по разметке ширин областей, т.е. без сюрпризов (хотя, может, наоборот надо бы каждый абзац в свой формат).

Умеет абзацы с минимумом форматирования, простые и нумерованные списки, таблицы.

 
 Весь исполняемый код

 

В коде я также постарался указать потенциально нужные возможности (на будущее, если понадобится) и некоторые нюансы. Пока рассчитано на А4 и документ из одной "колонки", это наиболее частые случаи в практике. Картинки вытаскивать не стал, но при нужде можно докрутить. Возможно, потребуется "пристрелка" секций по высоте.

Работать будет на любых 8.2 и 8.3, и на сервере, и на клиенте. В приведённом примере клиентский код.

Естественно, это БАЯН. Такое наверняка делали, не могли не делать. И, конечно, через OpenXML и прочая. Но я не заморачивался, да и хмл этот временами подкидывает неочевидные сюрпризы...

Кому пригодится, по-быстрому наваять макет по документу, например - вот и хорошо.

Word в табличный документ mxl doc макет печатной формы COM-обмен с

См. также

Универсальные функции Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    11642    dimanich70    80    

124

Универсальные функции Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    3365    3    John_d    11    

57

Универсальные функции Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    8167    atdonya    22    

55

Универсальные функции Программист Платформа 1С v8.3 Бесплатно (free)

На заключительных этапах, когда идет отладка или доработка интерфейса, необходимо много раз переоткрыть внешний объект. Вот один из способов автоматизации этого.

30.11.2023    4740    ke.92@mail.ru    16    

65

WEB-интеграция Универсальные функции Механизмы платформы 1С Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    11422    YA_418728146    7    

153

Пакетная печать Печатные формы Адаптация типовых решений Универсальные функции Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Абонемент ($m)

Расширение для программ 1С:Управление торговлей, 1С:Комплексная автоматизация, 1С:ERP, которое позволяет распечатывать печатные формы для непроведенных документов. Можно настроить, каким пользователям, какие конкретные формы документов разрешено печатать без проведения документа.

2 стартмани

22.08.2023    2821    43    progmaster    8    

4

Инструментарий разработчика Универсальные функции Платформа 1С v8.3 Конфигурации 1cv8 1С:Розница 2 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Абонемент ($m)

Копирует в буфер значения из списков, из ячеек отчетов, таблиц, настроек списков, других отборов и вставляет в выбранную настройку отбора. Работает с Объект не найден. Работает как в одной так и между разными базами 1С. Использует комбинации [Alt+C] Копировать список, [Alt+V] Вставить список. Также для копирования данных используется стандартная [Ctrl+C] (например из открытого xls, mxl, doc и т.п. файла скопировать список наименований)

1 стартмани

13.10.2022    17205    152    sapervodichka    112    

133
Вознаграждение за ответ
Показать полностью
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Дмитрий_DGR 20.08.21 11:27 Сейчас в теме
Получилось, большое спасибо, давно ждал такую обработку!
user1741387; +1 Ответить
2. gubanoff 63 23.08.21 13:45 Сейчас в теме
(0) Пожалуйста, добавьте готовую обработочку к статье для удобства
unknown181538; +1 Ответить
3. Perfolenta 206 25.08.21 01:25 Сейчас в теме
Спасибо, работает... хотя, я пока только на простых документах проверил, но уже понятно, что полезная штука...
4. ekonoya 05.09.21 13:34 Сейчас в теме
Благодарю, Вы очень выручили
5. fixin 4263 08.02.22 15:10 Сейчас в теме
Спасибо, обернул в обработку, работает.
Правда в УФ пришлось убрать ОбработкаПрерыванияПользователя.
Результат не так уж и много полировать пришлось.
Есть свои артефакты, конечно, но куда ж без них.
6. unknown181538 158 05.10.22 03:02 Сейчас в теме
Падала из-за недопустимых символов XML - добавил замену - все конвертнулось. По первому впечатлению - прилично. Вот код, обернутый в обработку.
Прикрепленные файлы:
КонвертнутьWORD.epf
baracuda; Breas; Ermigen; vanyek; Светлый ум; Ali_q; KoC_one; citkis; user591389_aska_rabota; graphbuh; assa; +11 Ответить
9. user1206119 86 19.03.24 09:44 Сейчас в теме
Огромное спасибо
(6) Ради эксперимента конвернул формат не A4 (Закоментил код).По итогу могу сказать - справилась на 3-ку. Этого более чем достаточно.
7. webester 26 28.08.23 05:34 Сейчас в теме
(0)Огромное спасибо тебе. На первый взгляд работает вполне себе прилично.
8. ivprovotorov 48 13.12.23 09:32 Сейчас в теме
Огромное спасибо! Помогло справиться с нудной работой по переводу из формата Word
10. One 04.07.24 13:47 Сейчас в теме
Автору огромное спасибо!!! Столько труда на общую пользу. Ещё раз спасибо!!!
Оставьте свое сообщение