Добавление команд печати в свои документы в Бухгалтерии 3.0




Принцип обмена данными из 1С с сайтом (на MySQL) и выдачи (публикации) этих данных по запросу.
PHP-Скрипт автоматической загрузки данных из файла данных в формате CSV в базу данных сайта работающего на WordPress.

В продолжение моей темы: 1С:Альфа-Авто Автосалон Автосервис: обмен с сайтом.
С помощью данного скрипта можно загружать в автоматическом режиме, по расписанию, данные сервисных книжек (ремонтов авто) из 1С:Альфа-Авто Автосалон Автосервис.
Также можно загружать данные в ручном режиме: для этого делается скрытая страница, где размещается специальная кнопка.
Комментарии размещенные внутри скрипта разъяснят логику и порядок действия.
Комментарии с "/////    echo" использовались для отладки.
Дополнительно создана таблица для журналирования результатов загрузки данных.
Скрипт включает в себя защиту от SQL инъекций (думаю безопасность соблюдена в полной мере).
В кратце:
1. Пишется скрипт, который запускает этот.
2. Создается регламентное задание в WordPress, по которому запускается скрипт из п.1. 
3. Этот скрипт осуществляет проверку на существование файла обмена в папке.
4. Если данные не новые, загрузка не производится.
5. Если данные новые, очищается таблица сервисных книжек.
6. Загружаются новые данные.

Собственно сам скрипт:

<?php // Полная загрузка сервисных книжек, создан 2026-01-05 12:44:55

global $wpdb2;
global $failure;
global $file_hist;

/////  echo '<H2><b>Старт загрузки</b></H2><br>';

$failure=FALSE;
//подключаемся к базе
$wpdb2 = include_once 'connection.php'; ; // подключаемся к MySQL
// если не удалось подключиться, и нужно оборвать PHP с сообщением об этой ошибке
if (!empty($wpdb2->error))
{
/////   echo '<H2><b>Ошибка подключения к БД, завершение.</b></H2><br>';
$failure=TRUE;
wp_die( $wpdb2->error );
}

$m_size_file=0;
$m_mtime_file=0;
$m_comment='';
/////проверка существования файлов выгрузки из 1С
////файл выгрузки сервисных книжек
$file_hist = ABSPATH.'/_1c_alfa_exchange/AA_hist.csv';
if (!file_exists($file_hist))
{
/////   echo '<H2><b>Файл обмена с сервисными книжками не существует.</b></H2><br>';
$m_comment='Файл обмена с сервисными книжками не существует';
$failure=TRUE;
}

/////инициируем таблицу лога
/////если не существует файла то возврат и ничего не делаем
if ($failure){
///включает защиту от SQL инъекций и данные можно передавать как есть, например: $_GET['foo']
/////   echo '<H2><b>Попытка вставить запись в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>$m_comment));
wp_die();
/////    echo '<H2><b>Возврат в начало.</b></H2><br>';
return $failure;
}
/////проверка лога загрузки, что бы не загружать тоже самое
$masiv_data_file=stat($file_hist);   ////передаем в массив свойство файла
$m_size_file=$masiv_data_file[7];    ////получаем размер файла
$m_mtime_file=$masiv_data_file[9];   ////получаем дату модификации файла
////создаем запрос на получение последней удачной загрузки
////выбираем по штампу времени создания (редактирования) файла загрузки AA_hist.csv, $m_mtime_file

/////   echo '<H2><b>Размер файла: '.$m_size_file.'</b></H2><br>';
/////   echo '<H2><b>Штамп времени файла: '.$m_mtime_file.'</b></H2><br>';
/////   echo '<H2><b>Формирование запроса на выборку из лога</b></H2><br>';
////препарируем запрос
$text_zaprosa=$wpdb2->prepare("SELECT * FROM `vin_logs` WHERE `last_mtime_upload` = %s", $m_mtime_file);
$results=$wpdb2->get_results($text_zaprosa);

if ($results)
{   foreach ( $results as $r)
{
////если штамп времени и размер файла совпадают, возврат
if (($r->last_mtime_upload==$m_mtime_file) && ($r->last_size_upload==$m_size_file))
{////echo '<H2><b>Возврат в начало, т.к. найдена запись в логе.</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>'Загрузка отменена, новых данных нет, т.к. найдена запись в логе.'));
wp_die();
return $failure;
}
}
}
////если данные новые, пишем в лог запись о начале загрузки
/////echo '<H2><b>Попытка вставить запись о начале загрузки в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>0, 'last_size_upload'=>$m_size_file, 'comment'=>'Начало загрузки'));

////очищаем таблицу
$clear_tbl_zap=$wpdb2->prepare("TRUNCATE TABLE %s", 'vin_history');
$clear_tbl_zap_repl=str_replace("'","`",$clear_tbl_zap);
$results=$wpdb2->query($clear_tbl_zap_repl);
/////   echo '<H2><b>Очистка таблицы сервисных книжек</b></H2><br>';
if (empty($results))
{
/////   echo '<H2><b>Ошибка очистки таблицы книжек, завершение.</b></H2><br>';
//// если очистка не удалась, возврат
$failure=TRUE;
wp_die();
return $failure;
}

////загружаем данные
$table='vin_history';         // Имя таблицы для импорта
//$file_hist Имя CSV файла, откуда берется информация     // (путь от корня web-сервера)
$delim=';';          // Разделитель полей в CSV файле
$enclosed='"';      // Кавычки для содержимого полей
$escaped='\

52 Comments

  1. paybaseme

    Самое интересное в предлагаемой Вами методике, осталось за кадром: если в форме списка выделить НЕСКОЛЬКО элементов (в вашем случае, приказов), то как же тогда будут напечатаны все Ваши документы, ежели Вы пишите:

    Ссылка = МассивОбъектов[0];

    Для одного объекта и будет напечатано.

    Полагаю, Вам нужно заглянуть в БСП.

    Reply
  2. nick-max

    (1) paybaseme,

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

    Да, из кода понятно, что если выделить шифтом несколько строк с документами, то можно напечатать их пакетно. Но для меня это ненужная функция. Однако, спасибо, что обратили на это внимание, может кому-то будет полезно)

    Reply
  3. paybaseme

    (2)

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

    Я ключевую неточность у Вас подчеркнул. В БП 3.0 портирована подсистема «Печать». Механизм печати, в части касающейся Вашей статьи, одинаков для конфигураций, где данная подсистема уже внедрена. Т.е. «фреймворк» печати (в вашей терминологии), уже встроен в БП 3.0. И говорить, что Ваша статья «опирается на функционал этой конфигурации.» видимо, не совсем, точно. Ваша статья опирается на использование типовой подсистемы «Печать» из БСП.

    Все выше сказанное, не в критику, а в уточнение 🙂

    Reply
  4. nick-max

    (3) paybaseme,

    Спасибо за уточнение

    Значит эта статья кросс-конфигурационная)

    Reply
  5. Saifa

    Статья мне пригодилась, спасибо!

    Reply
  6. nixel

    В БП 3.0 помимо подсистемы «Печать» встроена подсистема «Дополнительные отчеты и обработки», которая позволяет вообще без внесения изменений в конфигурацию добавлять произвольные команды печати и обработок в документы. Единственное требование от конфигурации — наличие документа/справочника в определенной подписке. Если этого нет, то контроллировать изменение одной/двух подписок намного проще, чем модулей объекта и менеджера. Сама же печать располагается во внешней обработке, которая имеет в своем модуле информацию для подключения к какому-либо документу, и все это дело настраивается в пользовательском режиме.

    Как уже писалось выше, почитайте документацию по новой БСП, там правда много интересного 🙂

    Reply
  7. AleksSF

    А через команды документа и конструкторы не пробовали. Там все автоматом размещается и на форму документа и на форму списка. В БП 3.0 как и во всех управляемых приложениях ко многим вещам другой подход. И лучше как следует изучить новую конфигурацию, а затем переносить свои изменения. Иначе получиться изобретение велосипеда.

    Reply
  8. nick-max

    (7) AleksSF,

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

    Reply
  9. AleksSF

    (8)

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

    Reply
  10. Bukaska

    (1) paybaseme, Я думаю множественная печать и Без БСП реализуется, если глянуть в типовую..

    Для этого даже с самодельными печатными формами вместо ссылки на объект, делаем

    Запрос.УстановитьПараметр(«МассивОбъектов», МассивОбъектов)

    А в самом запросе:

    …
    ГДЕ
    НужноеПоле.Ссылка В(&МассивОбъектов)

    И переменную результата запроса Шапка прокрутить в цикле и усе.. и все будет ОК))))

    Это как раз если внешнюю печатную форму встраивать через доп.Отчеты и обработки))))

    Reply
  11. paybaseme

    (10) Bukaska,

    Я думаю множественная печать и Без БСП реализуется, если глянуть в типовую..

    Все таки, по внимательнее перечитайте (3). Если Вы гляните в типовую БП 3.0, то все о чем Вы написали, НЕ ИМЕЕТ СМЫСЛА без внедренной подсистемы «Печать». Поэтому, Ваши думы о том, что множественная печать реализуется БЕЗ БСП, могут существовать в контексте Ваших исключительных рассуждений и дум 🙂 А если глубже копнуть, то выяснится, что ваш алгоритм — это типовая методика, которую можно было увидеть в БСП версии 1.0.7.5 от 05.08.2010, в то время как БП 3.0 зарелизилась с версии 3.0.9.4 от 28.04.2012. Т.е., тот алгоритм, который Вы описали, опирается на обвяз, который уже был представлен в демо БСП практически за 2 года, до первого релиза БП 3.0

    Это как раз если внешнюю печатную форму встраивать через доп.Отчеты и обработки

    А это, в свою очередь, еще одна подсистема БСП под названием «Дополнительные отчеты и обработки», которая также портирована в БП 3.0

    Итоги моего поста какие? 🙂

    Reply
  12. Bukaska

    (11) paybaseme, Я сказала именно про множественную печать, что не нужно так глубоко копать для привязки ВПФ к документу)))

    Вопрос в том, как по вашей методике согласно публикации сделать так, чтобы работала множественная печать.А то нулевой индекс строки правильно ребята подметили, — это печать одного документа, как будто из бух 2.0 печатаем)

    Reply
  13. paybaseme

    (12) Bukaska,

    не нужно так глубоко копать для привязки ВПФ к документу

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

    Надо за правило взять, если что-то по печати, доп.отчетам и обработкам, ролям и прочему не понятно — то первое что надо делать, это не пытаться раскуривать самому, а скачать демо БСП, той редакции, которая сейчас в типовой, и посмотреть примеры.

    Пожалуйста! Всегда Ваш, Кэп.

    🙂

    Reply
  14. Bukaska

    (13) paybaseme, БСП недоступна ни по учетке учебной версии, ни по комплекту разраба вроде как.. Это только франям..)))

    Если бы оно везде на ресурсах валялось.. другой бы разговор)))

    Лучше подскажите как в типовой найти версию БСП, и где посмотреть справку о функционале БСП.

    Reply
  15. paybaseme

    (14) Bukaska,

    Reply
  16. Bukaska

    (15) paybaseme, Спасибо! А как в типовой бух 3.0 выйти на эту справку?

    Reply
  17. paybaseme

    (16) Bukaska,

    А как в типовой бух 3.0 выйти на эту справку?

    1. Версия подсистем — РС

    2. Справка по подсистемам БСП — никак. Только на ИТС.

    Reply
  18. Bukaska

    (17) paybaseme, ну вот.. опять двадцать пять((( жаль.. Ладно.. может меня когда-нить и допустят до ИТС)))

    Reply
  19. paybaseme

    (18) Bukaska,

    может меня когда-нить и допустят до ИТС

    Если у Вас ваше скромное чувство собственного «я» позволит себя допустить до ИТС, то для этого нужно сделать всего лишь четыре шага:

    1. Зарегать новый e-mail

    2. Открыть http://its.1c.ru/test-drive/

    3. Получить доступ к ИТС по е-mail из п.1 на 7 дней

    4. Через 7 дней, выполнить в п.1

    Пожалуйста! Всегда Ваш, Кэп.

    Reply
  20. Bukaska

    (2) Вот теперь спасибо! Правда вперед ИТС под рукой был)))) есть другой вопрос, по части внешних печатных форм для самодельных документов. Эти все дела по вашей публикации я сделала, потом отлаживаю сейчас родной макет самодельного документа.. но вот Внешнюю печатную форму не зарегить, выскакивает ошибка: Тип не определен.ДокументСсылка.ИмяДокумента.. В Общую команду составного типа добавила свой док, но все равно видать что-то где-то не хватает… Благо что хоть родной макет отлаживается))))

    Reply
  21. oleg212

    Спасибо за статью.

    Reply
  22. SoulCast

    Спасибо, сделал по этой схеме несколько печатных форм в новых документах. Как раз в процессе переход на БП 3.0 )) А есть идеи как передать в процедуру печати дополнительные параметры?

    Reply
  23. mie24

    (20) Bukaska, Чтобы к новому документу иметь возможность подключить ВПФ необходимо этот документ указать в списке Типов параметров Общей команды «ДополнительныеОтчетыИОбработкиПечатныеФормы», а лучше подстраховаться и указать новый(ые) документ(ы) и в других Общих командах «ДополнительныеОтчетыИОбработкиОтчеты», «ДополнительныеОтчетыИОбработкиЗаполнениеОбъекта», «ДополнительныеОтчетыИОбработкиСозданиеСвязанныхОбъектов».

    Далее необходимо в Модуле формы (Документа и Списка) нового документа необходимо создать процедуру ПриСозданииНаСервере:

    &

    НаСервере
    Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
    // СтандартныеПодсистемы.Печать
    УправлениеПечатью.ПриСозданииНаСервере(ЭтаФорма);
    // Конец СтандартныеПодсистемы.Печать
    
    // ДополнительныеОтчетыИОбработки
    ДополнительныеОтчетыИОбработки.ПриСозданииНаСервере(ЭтаФорма);
    // Конец ДополнительныеОтчетыИОбработки
    
    Если Параметры.Ключ.Пустая() Тогда
    ПодготовитьФормуНаСервере();
    КонецЕсли;
    
    КонецПроцедуры
    

    Показать

    Кажется этого должно быть достаточно.

    Только нужно еще проверить на форме на панели (Вид — ГруппаКнопок и Источник — Форма) появилась ли кнопка Печать с выпадающим меню «ДополнительныеПечатныеФормы»

    Reply
  24. nick-max

    (22) SoulCast,

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

    Reply
  25. SoulCast

    (24) например получить текущую строку табличной части. У меня были печатные формы, которые получали данные по выбранной строке.

    Reply
  26. Dima69

    Спасибо очень помогло

    Reply
  27. Dima69

    Да чуть не забыл, а не подскажите какие стандартные процедуры

    ставят значок Дб-Кр (при ручной корректировки операции) в списке документов

    Reply
  28. nick-max

    (27) Dima69,

    для выведения на форму кнопки ДтКт нужно добавить свой документ в общую команду ПоказатьДвиженияДокумента.

    Но с точки зрения доработки типовой конфигурации с минимальными изменениями в типовых объектах лучше всего скопировать эту общую команду, назвать ПоказатьДвиженияМоегоДокумента и указывать в ней только свои документы. Тогда при обновлении кнопка ДтКт точно не слетит

    Reply
  29. Dima69

    Спасибо за ответ, но я имел в виду не кнопку ДтКт,

    а значок ДтКт левее документа, операция которого отредактированна вручную, рядом

    с зеленой галкой проведенного документа

    Reply
  30. sudmorsh

    Спасибо за статью очень пригодилась

    Reply
  31. jobkostya1c8

    Интересная статья про печать в БП 3.0 с использованием стандартных механизмов. Но, может быть, даже для новых нетиповых документов использовать внешние печатные формы если нужно оперативно (не выгоняя пользователей) исправить ошибку при печати?

    Печатную форму сделать проще чем копаться в механизмах печати новых релизов? Постоянно ведь корректировать конфигурацию будет затруднительно? Особенно если новых документов много.

    Reply
  32. Astafan

    Спасибо за статью, очень пригодилась.

    Но есть один вопрос: Создал в типовой конфигурации новый документ. Чтобы использовать механизм подключаемых печатных форм нужно редактировать команду «ДополнительныеОтчетыИОбработкиПечатныеФормы». НО при обновлении изменения слетят. Как правильно поступить в данном случае?

    Reply
  33. ekaterinaeon

    Нашла эту статью как раз в тот момент, когда больше всего была нужна) и помогло! спасибо!

    Reply
  34. helox
    В процедуре Процедура ДобавитьКомандыПечати(КомандыПечати) Экспорт
    
    КомандаПечати = КомандыПечати.Добавить();
    КомандаПечати.Идентификатор = «Акт»;
    КомандаПечати.Представление = «Дополнительный акт»;
    КомандаПечати.Обработчик    = «УправлениеПечатьюБПКлиент.ВыполнитьКомандуПечати»;
    КомандаПечати.СписокФорм    = «ФормаСписка,ФормаДокумента»; 

    в списке форм должны быть наименования форм используемых при печати, добавил форму «ФормаДокументаУФ» — и долго гадал почему не появилась кнопочка печати!!

    Reply
  35. ronhard
    Также у этого списка обязательно должна быть колонка Ссылка, пусть даже невидимая

    В конфигураторе на форме у колонки «Ссылка» должна стоять галочка «Использовать всегда», иначе невидимая колонка работать не будет, а только если она видимая.

    Reply
  36. ui69

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

    Reply
  37. Baser

    А можете ссылку дать, как это более правильно делать? Я уже который день пытаюсь понять, как свою печать через БСП пустить, а не по старинке, через команды; везде методики для использования во внешних печатных формах

    Ну, вот почему так… как вопрос задал, так сразу и нашел… спасибо всем 🙂

    http://its.1c.ru/db/bspdoc#content:219:1:issogl2_%D1%80%D0%B0%D0%B7%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%­BA%D0%B0_%D0%BF%D1%80%D0%BE%D1%86%D0%B5%D0%B4%D1%83%D1%80%D1­%8B_%D0%BF%D0%B5%D1%87%D0%B0%D1%82%D1%8C

    Reply
  38. user590836_zhan_chick

    Теперь у меня программно добавились 2 лишние кнопки печати, которые мне не нужны. Помимо тех что созданы на форме вручную. Вопрос: как мне их убрать?

    Reply
  39. zmx

    В форме списка документа в процедуре ВыполнитьПодключаемуюКомандуПечати нужно поставить условие выполнения печати только, если документ проведен. Почему здесь не виден реквизит проведения документа?

    Процедура Подключаемый_ВыполнитьКомандуПечати(Команда)

    Объект=Элементы.Список.ТекущаяСтрока;

    Если Объект.Проведен = Ложь Тогда

    Сообщить(«Документ не проведен !!! Печать не возможна»);

    Возврат;

    КонецЕсли;

    УправлениеПечатьюКлиент.ВыполнитьПодключаемуюКомандуПечати(Команда, ЭтаФорма, Элементы.Список);

    КонецПроцедуры

    Спасибо заранее!

    Reply
  40. nick-max

    (39) zmx,

    думаю, тут лучше использовать Элементы.Список.ТекущиеДанные.Ссылка.Проведен, при условии, что в список выведена колонка Ссылка. Но я бы такие проверки перенес внутрь функций типа СформироватьПриказ

    Reply
  41. Perk0n

    Be aware.. в новой БСП поменяли принцип подключения своих команд. Статью бы немного дополнить, так как в данном виде она утратила свою актуальность.

    Вместо методов из «СтандартныеПодсистемы.Печать»

    &НаКлиенте
    Процедура Подключаемый_ВыполнитьКомандуПечати(Команда)
    УправлениеПечатьюКлиент.ВыполнитьПодключаемуюКомандуПечати(Команда, ЭтаФорма, Объект)
    КонецПроцедуры
    

    Следует использовать методы из «СтандартныеПодсистемы.ПодключаемыеКоманды»

    &НаКлиенте
    Процедура Подключаемый_ВыполнитьКоманду(Команда)
    ПодключаемыеКомандыКлиент.ВыполнитьКоманду(ЭтотОбъект, Команда, Объект);
    КонецПроцедуры
    
    Reply
  42. slauter77

    Спасибо за предупреждение! (41)

    От себя добавлю, что например в Бух КОРП 3.0.52.39 нужно в модуле: «ОбщийМодуль.УправлениеПечатьюПереопределяемый»

    в процедуру:

     Процедура ПриОпределенииОбъектовСКомандамиПечати(СписокОбъектов) Экспорт 

    добавить строку типа:

    СписокОбъектов.Добавить(Документы.ИмяВашегоДокумента)

    тогда, с учетом изменений описанных Вами, печать заработает!

    (просто сам долго копался с этим)

    Reply
  43. 777Ferz777

    С новыми обновами, новые веянья

    Вызовы вида:

    // СтандартныеПодсистемы.Печать
    &НаКлиенте
    Процедура Подключаемый_ВыполнитьКомандуПечати(Команда)
    УправлениеПечатьюКлиент.ВыполнитьПодключаемуюКомандуПечати(Команда, ЭтотОбъект, Объект);
    КонецПроцедуры
    // Конец СтандартныеПодсистемы.Печать

    следует заменить вызовами:

    // СтандартныеПодсистемы.ПодключаемыеКоманды
    &НаКлиенте
    Процедура Подключаемый_ВыполнитьКоманду(Команда)
    ПодключаемыеКомандыКлиент.ВыполнитьКоманду(ЭтотОбъект, Команда, <ОбъектИлиТаблицаФормы>);
    КонецПроцедуры
    
    &НаСервере
    Процедура Подключаемый_ВыполнитьКомандуНаСервере(Контекст, Результат)
    ПодключаемыеКоманды.ВыполнитьКоманду(ЭтотОбъект, Контекст, <ОбъектИлиТаблицаФормы>, Результат);
    КонецПроцедуры
    
    // Конец СтандартныеПодсистемы.ПодключаемыеКоманды

    Показать

    более подробно читайте здесь http://downloads.v8.1c.ru/content/SSL/2_4_3_84/change.htm

    Reply
  44. nadjushka

    Добавление команд печати в Бухгалтерии 3.0 после релиза 3.0.52.35

    http://1c-soft.it-terminal.ru/public/674880/

    Reply
  45. bds22

    в бухгалтерии корп 3.0 мне для того, чтобы появилась возможность печати в моем документе, пришлось в общем модуле «Управление печатью переопределяемый»

    в эту процедуру добавить свой документ

    Процедура ПриОпределенииОбъектовСКомандамиПечати(СписокОбъектов) Экспорт

    там такие строки

    СписокОбъектов.Добавить(Документы.ПоступлениеТоваровУслуг);
    СписокОбъектов.Добавить(Документы.ПринятиеКУчетуНМА);
    СписокОбъектов.Добавить(Документы.ПринятиеКУчетуОС);
    СписокОбъектов.Добавить(Документы.ПриходныйКассовыйОрдер);
    СписокОбъектов.Добавить(Документы.РаспределениеНДС);
    СписокОбъектов.Добавить(Документы.РасходныйКассовыйОрдер);

    и так далее — все документы

    Reply
  46. CatZero

    (45) Спасибо!!!!!

    Reply
  47. liric

    А если я хочу просто напечатать документ в своей самописанной конфе где нет никаких БСП и конструкторы печати теперь не работают. Что делать?

    Reply
  48. newvideo

    УНФ 1.6.5. БСП 2.3.1.53

    в модуле УправлениеПечатьюСлужебныйКлиент

    в процедуре ВыполнитьПодключаемуюКомандуПечатиПодготовкаОбъектовПечати

    вываливается:

    {ОбщийМодуль.УправлениеПечатьюСлужебныйКлиент.Модуль(125)}: Ошибка компиляции при вычислении выражения или выполнении фрагмента кода Результат = Вычислить(Обработчик);

    по причине:

    {(1,1)}: Переменная не определена (УправлениеПечатьюБПКлиент)

    <<?>>УправлениеПечатьюБПКлиент.ВыполнитьКомандуПечати(ОписаниеКоманды)

    Менял в Модуле Менеджера Документа

    УправлениеПечатьюБПКлиент на УправлениеПечатьюКлиент и также на

    Подключаемый_ВыполнитьКомандуПечати

    всёравно ошибки, куда же копать?

    Reply
  49. vis_tmp

    (45) А в самом документе что нужно добавить?

    Reply
  50. den_vrn

    (35)

    «Использовать всегда»

    не могу найти где эта галочка блин ….

    Reply
  51. XelOla

    (48) вы разобрались?

    ТОже не могу для УНФ вывести

    Reply
  52. newvideo

    (51) давно это было, помню только что разобрался, а что именно сделал к сожалению уже не вспомню) Но конфигурация под рукой, могу сказать что где есть)

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *