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

18.08.21

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

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

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

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

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

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

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

 

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

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

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

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

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

См. также

Вставляем картинку из буфера обмена (платформа 1С 8.3.24)

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

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

1 стартмани

18.03.2024    2946    2    John_d    11    

56

GUID в 1С 8.3 - как с ними быть

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

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

12.02.2024    5262    atdonya    22    

52

Переоткрытие внешних обработок

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

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

30.11.2023    4162    ke.92@mail.ru    16    

62

Валидация JSON через XDTO (включая массивы)

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

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

28.08.2023    9600    YA_418728146    6    

143

Печать непроведенных документов для УТ, КА, ERP. Настройка печати по пользователям, документам и печатным формам

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

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

2 стартмани

22.08.2023    2300    28    progmaster    8    

3

Расширение: Быстрые отборы через буфер [Alt+C] Копировать список, [Alt+V] Вставить список, [Ctrl+C] Копировать из файлов

Инструментарий разработчика Универсальные функции Платформа 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    16443    144    sapervodichka    112    

130

Система контроля ведения учета [БСП]

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

В данном материале рассмотрим типовой алгоритм подсистемы контроля учета БСП в конфигурациях на примерах.

18.07.2022    7394    quazare    8    

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