Объединение нескольких печатных форм в один табличный документ

17.11.18

Разработка - Инструментарий разработчика

Простое решение, как объединить табличные документы с различной шириной колонок в один и чтобы ничего не разъехалось.

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
Отчет на СКД с логотипом. Объединение табличных документов
.erf 238,70Kb
25 1 850 руб. Купить

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

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

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

Зачем это нужно, где это может пригодиться

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

Отчеты разъехались

Рис.1. Ширина колонок изменилась и логотип сместился вправо.

При каких сценариях это происходит:

  • При объединении нескольких печатных форм в один табличный документ;
  • При дополнении отчета на СКД областью из своего макета.

Суть решения

Все просто - в момент присоединения одного табличного документа к другому мы создаем для него новый формат строк. По сути тоже самое, что происходит при интерактивном редактировании макета, когда вы выделяете строки и изменяете для них ширину столбца.

Рис.2. Табличный документ из двух частей. Создан новый формат строк.

Для выделенных ячеек будет создан новый формат строк

Рис. 3. Вопрос в редакторе табличного документа при изменении ширины столбцов.

 
  Код процедуры

В качестве бонуса отчет на СКД с логотипом.

Подобная публикация Вывод различных табличных документов в один ("склеивание" печатных форм)

Тестировалось на платформе 8.3.13.1513

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

Склеивание печатных форм объединение табличных документов табдок макет разная ширина колонок

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    206407    1133    411    

1030

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

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    37078    212    111    

199

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

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

16000 руб.

10.11.2023    16859    73    39    

89

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    24463    65    28    

93

Инструментарий разработчика Программист 1С v8.3 1С:Управление нашей фирмой 3.0 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9500 руб.

17.05.2024    35477    129    53    

171

SALE! 30%

Инструментарий разработчика WEB-интеграция 1С v8.3 1C v8.2 1C:Бухгалтерия 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Инструмент для генерации OpenApi (Swagger) спецификаций на основании файлов конфигураций 1С. Это консольное и десктопное приложение на языке Rust с полноценным редактором кода, содержащим автозамену и подсвечивание ошибок для быстрого и безошибочного написания документирующего комментария.

18000 12600 руб.

22.11.2024    2071    1    0    

8

Инструментарий разработчика Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

6000 руб.

07.02.2018    107883    249    100    

313
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. wolfsoft 2421 03.07.19 15:56 Сейчас в теме
Всё равно ширина колонок будет одна и та же в обоих макетах, т.е. уедет ваш второй макет от изначального шаблона. Или я ошибаюсь? Точно, ошибаюсь, проверил :) Тогда "плюс" :)
2. echo77 1926 03.07.19 16:02 Сейчас в теме
(1) Я сто раз так делал :-) У меня даже в шаблонах эта процедура, ибо иногда приходится...
3. Orlando Skibraves 5 15.08.19 13:16 Сейчас в теме
Если в табличном документе было объединение ячеек по высоте, эта область искажается
4. tonyS 25.01.20 19:55 Сейчас в теме
Спасибо большое за процедуру, очень помогла!
5. VladIsLooove23 04.08.20 16:36 Сейчас в теме
Коллеги доброго времени суток, есть функция которая получает сформированные Печатные формы(далее ПФ) у каждого табдока есть параметр "ШиринаТаблицы" для всех сформированных ПФ разный(зависит от макета) и объединяет их в большойТАбДОк.
При попытке вывести на печать наш большойТАбДОк (при условии что для него АвтоМасштаб = Истина) получается что та ПФ которая с меньшим параметром "ШиринаТаблицы" становится нечитаемым(скрин прилагается) . Хотелось узнать можно ли как то решить эту проблему не унифицируя все макеты ПФ?

ПЫСЫ: параметр ШиринаТаблицы недоступен для записи.
Прикрепленные файлы:
6. VladIsLooove23 04.08.20 16:36 Сейчас в теме
(5) Пробовал использовать процедурку описанную в топике , не помогло.)
Мб кто сталкивался?
7. RustIG 1897 29.12.21 18:50 Сейчас в теме
Особенности использования форматированных строк описаны на ИТС
Особенности работы с форматами строк табличного документа

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

Если в присоединяемом табл. документе много разных блоков - с разными форматами строк, то алгоритм уже не сработает - поскольку все последующие строки табл. документа будут приводиться к формату первого блока строк....

Поможет алгоритм вот отсюда Объединение табл. документов

Автор алгоритма потрудился разделить присоединяемый табл.документ на все блоки разных форматов строк - присоединил каждый по отдельности. Ему огромное спасибо за предоставленный алгоритм!

Расскажу в чем нюанс. Сначала я выводил так таб. документы:
ТабДок1 = ПечатьРасходногоОрдераНаТовары(МассивОбъектов, ОбъектыПечати);
		ТабДок2 = Обработки.ДопПечать_ПечатьРасходногоОрдераИЗаданияНаОтбор.СформироватьРасходныйОрдерИЗаданиеНаОтбор(МассивОбъектов, ОбъектыПечати, ПараметрыПечати);
		
		ТабДок = Новый ТабличныйДокумент;
			
		ТабДок.Вывести(ТабДок1);
		ТабДок.Вывести(ТабДок2);
Показать


В таком случае два макета садятся в один - с первого взгляда красиво, но в формат А4 Портрет уже не влезает - колонки изменяют ширину. По отдельности каждый макет влезает в А4.

Пришлось воспользоваться алгоритмом соединения табл. документов через СоздатьФорматСтрок() - результат положительный и представлен на скриншотах.
Прикрепленные файлы:
8. user796327 27.03.22 08:52 Сейчас в теме
(7)Здравствуйте! Использую алгоритм по ссылке https://forum.infostart.ru/redirect.php?url=aHR0cHM6Ly9mb3J1bS5taXN0YS5ydS90b3BpYy5waHA/aWQ9ODM3NzEx­.
Мне нужно счет и счет-фактуру сделать на одном листе. И оба Портрет. Макет счет-фактуры типовой. Приходится делать автомасштаб. Но тогда и счет уменьшается в размерах.
Прикрепленные файлы:
ВПФ_СчетСчФактура_копия для форума.epf
9. RustIG 1897 28.03.22 09:23 Сейчас в теме
10. user796327 28.03.22 12:28 Сейчас в теме
(9) используя алгоритм https://forum.infostart.ru/redirect.php?url=aHR0cHM6Ly9mb3J1bS5taXN0YS5ydS90b3BpYy5waHA/aWQ9ODM3NzEx­­ получится реализовать мою задачу: счет (макет портрет) и счет-фактуру (макет ландшафт) сделать в одном табличном документе портрет? у меня не получается.
17. Dunda 49 13.03.23 21:16 Сейчас в теме
А можно ли сохранить в pdf два разных формата в один файл? например, чтобы один лист был размером a5, а другой а3 например?
12. e-9 62 15.06.22 20:05 Сейчас в теме
Коллеги, а как победить вывод на печать таких склеенных, с использованием СоздатьФорматСтрок(), таблдоков? см. скрин: на нем два таблдока с разными форматами строк; на предпросмотре "сжимаются", заняв лишь малое пространство. При печати по отдельности - все ок.
Прикрепленные файлы:
13. RustIG 1897 16.06.22 08:56 Сейчас в теме
(12) ТаблДок1.Ориентация = Ландшафт;
ТаблДок2.Ориентация = Ландшафт;
ТаблкДок.Ориентация = Ландшафт;

ТаблДок.Режим печати = по ширине странице
14. e-9 62 16.06.22 10:05 Сейчас в теме
(13) то что в (12) вчера удалось победить, уже не помню как)
Но началось другое - и вот с этим ничего не помогло (на скрине). Даже перенос в один отчет, т.е. работаю с одним макетом, в который скопировал вручную (вместе с форматом строк) области макета другого отчета.
Упорно при печати пихает пустые страницы, по две на одну заполненную. В макете никаких "артефактов" (типа объединенных ячеек) справа нет.
Прикрепленные файлы:
15. e-9 62 16.06.22 10:47 Сейчас в теме
(14) да, есть нюанс: вывод происходит в ПолеТабличногоДокумента
16. RustIG 1897 16.06.22 12:47 Сейчас в теме
(15) я не думаю что это нюанс
помню - станицы пустые были, когда незаметно сдвинул "область печати"
есть такая менюшка - показать или задать область печати - вот ее проверьте
Оставьте свое сообщение