<?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='\
Самое интересное в предлагаемой Вами методике, осталось за кадром: если в форме списка выделить НЕСКОЛЬКО элементов (в вашем случае, приказов), то как же тогда будут напечатаны все Ваши документы, ежели Вы пишите:
Для одного объекта и будет напечатано.
Полагаю, Вам нужно заглянуть в БСП.
(1) paybaseme,
Понятно, что где-то реализованы целые блоки и фреймворки для управления печатью. Эта статья только для Бухгалтерии 3.0, она полностью опирается на функционал этой конфигурации.
Да, из кода понятно, что если выделить шифтом несколько строк с документами, то можно напечатать их пакетно. Но для меня это ненужная функция. Однако, спасибо, что обратили на это внимание, может кому-то будет полезно)
(2)
Я ключевую неточность у Вас подчеркнул. В БП 3.0 портирована подсистема «Печать». Механизм печати, в части касающейся Вашей статьи, одинаков для конфигураций, где данная подсистема уже внедрена. Т.е. «фреймворк» печати (в вашей терминологии), уже встроен в БП 3.0. И говорить, что Ваша статья «опирается на функционал этой конфигурации.» видимо, не совсем, точно. Ваша статья опирается на использование типовой подсистемы «Печать» из БСП.
Все выше сказанное, не в критику, а в уточнение 🙂
(3) paybaseme,
Спасибо за уточнение
Значит эта статья кросс-конфигурационная)
Статья мне пригодилась, спасибо!
В БП 3.0 помимо подсистемы «Печать» встроена подсистема «Дополнительные отчеты и обработки», которая позволяет вообще без внесения изменений в конфигурацию добавлять произвольные команды печати и обработок в документы. Единственное требование от конфигурации — наличие документа/справочника в определенной подписке. Если этого нет, то контроллировать изменение одной/двух подписок намного проще, чем модулей объекта и менеджера. Сама же печать располагается во внешней обработке, которая имеет в своем модуле информацию для подключения к какому-либо документу, и все это дело настраивается в пользовательском режиме.
Как уже писалось выше, почитайте документацию по новой БСП, там правда много интересного 🙂
А через команды документа и конструкторы не пробовали. Там все автоматом размещается и на форму документа и на форму списка. В БП 3.0 как и во всех управляемых приложениях ко многим вещам другой подход. И лучше как следует изучить новую конфигурацию, а затем переносить свои изменения. Иначе получиться изобретение велосипеда.
(7) AleksSF,
Пробовал, конечно, с этого и начал. Но такая печать просто формирует и открывает табличный документ, а мне требовалось, чтобы он открывался в форме с кнопкой «Печать», количеством экземпляров, возможностью сохранить
(8)
В принципе Ваш способ имеет право жить, если в конфигурацию добавляешь свои Документы. Но для стандартных документов все же лучше использовать Дополнительные внешние печатные формы. Они добавляются с таким-же функционалом. Но при обновлениях ничего не будет пропадать и для последователей более прозрачно. Поэтому +.
(1) 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
Итоги моего поста какие? 🙂
(11) paybaseme, Я сказала именно про множественную печать, что не нужно так глубоко копать для привязки ВПФ к документу)))
Вопрос в том, как по вашей методике согласно публикации сделать так, чтобы работала множественная печать.А то нулевой индекс строки правильно ребята подметили, — это печать одного документа, как будто из бух 2.0 печатаем)
(12) Bukaska,
Как раз таки нужно, ибо если не копать, тогда сложится мнение как у вас и у вашего коллеги: что оно якобы как-то само там живет, в типовой, своей жизнью.
Надо за правило взять, если что-то по печати, доп.отчетам и обработкам, ролям и прочему не понятно — то первое что надо делать, это не пытаться раскуривать самому, а скачать демо БСП, той редакции, которая сейчас в типовой, и посмотреть примеры.
Пожалуйста! Всегда Ваш, Кэп.
🙂
(13) paybaseme, БСП недоступна ни по учетке учебной версии, ни по комплекту разраба вроде как.. Это только франям..)))
Если бы оно везде на ресурсах валялось.. другой бы разговор)))
Лучше подскажите как в типовой найти версию БСП, и где посмотреть справку о функционале БСП.
(14) Bukaska,
(15) paybaseme, Спасибо! А как в типовой бух 3.0 выйти на эту справку?
(16) Bukaska,
1. Версия подсистем — РС
2. Справка по подсистемам БСП — никак. Только на ИТС.
(17) paybaseme, ну вот.. опять двадцать пять((( жаль.. Ладно.. может меня когда-нить и допустят до ИТС)))
(18) Bukaska,
Если у Вас ваше скромное чувство собственного «я» позволит себя допустить до ИТС, то для этого нужно сделать всего лишь четыре шага:
1. Зарегать новый e-mail
2. Открыть
3. Получить доступ к ИТС по е-mail из п.1 на 7 дней
4. Через 7 дней, выполнить в п.1
Пожалуйста! Всегда Ваш, Кэп.
(2) Вот теперь спасибо! Правда вперед ИТС под рукой был)))) есть другой вопрос, по части внешних печатных форм для самодельных документов. Эти все дела по вашей публикации я сделала, потом отлаживаю сейчас родной макет самодельного документа.. но вот Внешнюю печатную форму не зарегить, выскакивает ошибка: Тип не определен.ДокументСсылка.ИмяДокумента.. В Общую команду составного типа добавила свой док, но все равно видать что-то где-то не хватает… Благо что хоть родной макет отлаживается))))
Спасибо за статью.
Спасибо, сделал по этой схеме несколько печатных форм в новых документах. Как раз в процессе переход на БП 3.0 )) А есть идеи как передать в процедуру печати дополнительные параметры?
(20) Bukaska, Чтобы к новому документу иметь возможность подключить ВПФ необходимо этот документ указать в списке Типов параметров Общей команды «ДополнительныеОтчетыИОбработкиПечатныеФормы», а лучше подстраховаться и указать новый(ые) документ(ы) и в других Общих командах «ДополнительныеОтчетыИОбработкиОтчеты», «ДополнительныеОтчетыИОбработкиЗаполнениеОбъекта», «ДополнительныеОтчетыИОбработкиСозданиеСвязанныхОбъектов».
Далее необходимо в Модуле формы (Документа и Списка) нового документа необходимо создать процедуру ПриСозданииНаСервере:
&
Показать
Кажется этого должно быть достаточно.
Только нужно еще проверить на форме на панели (Вид — ГруппаКнопок и Источник — Форма) появилась ли кнопка Печать с выпадающим меню «ДополнительныеПечатныеФормы»
(22) SoulCast,
а для чего это может быть нужно? то есть, какой например может быть доп. параметр, и почему его нельзя получить уже внутри процедуры типа СформироватьАкт?
(24) например получить текущую строку табличной части. У меня были печатные формы, которые получали данные по выбранной строке.
Спасибо очень помогло
Да чуть не забыл, а не подскажите какие стандартные процедуры
ставят значок Дб-Кр (при ручной корректировки операции) в списке документов
(27) Dima69,
для выведения на форму кнопки ДтКт нужно добавить свой документ в общую команду ПоказатьДвиженияДокумента.
Но с точки зрения доработки типовой конфигурации с минимальными изменениями в типовых объектах лучше всего скопировать эту общую команду, назвать ПоказатьДвиженияМоегоДокумента и указывать в ней только свои документы. Тогда при обновлении кнопка ДтКт точно не слетит
Спасибо за ответ, но я имел в виду не кнопку ДтКт,
а значок ДтКт левее документа, операция которого отредактированна вручную, рядом
с зеленой галкой проведенного документа
Спасибо за статью очень пригодилась
Интересная статья про печать в БП 3.0 с использованием стандартных механизмов. Но, может быть, даже для новых нетиповых документов использовать внешние печатные формы если нужно оперативно (не выгоняя пользователей) исправить ошибку при печати?
Печатную форму сделать проще чем копаться в механизмах печати новых релизов? Постоянно ведь корректировать конфигурацию будет затруднительно? Особенно если новых документов много.
Спасибо за статью, очень пригодилась.
Но есть один вопрос: Создал в типовой конфигурации новый документ. Чтобы использовать механизм подключаемых печатных форм нужно редактировать команду «ДополнительныеОтчетыИОбработкиПечатныеФормы». НО при обновлении изменения слетят. Как правильно поступить в данном случае?
Нашла эту статью как раз в тот момент, когда больше всего была нужна) и помогло! спасибо!
в списке форм должны быть наименования форм используемых при печати, добавил форму «ФормаДокументаУФ» — и долго гадал почему не появилась кнопочка печати!!
В конфигураторе на форме у колонки «Ссылка» должна стоять галочка «Использовать всегда», иначе невидимая колонка работать не будет, а только если она видимая.
Спасибо, помогла данная статья. Создавал новый документ в БП 3.0 с двумя печатными формами.
А можете ссылку дать, как это более правильно делать? Я уже который день пытаюсь понять, как свою печать через БСП пустить, а не по старинке, через команды; везде методики для использования во внешних печатных формах
Ну, вот почему так… как вопрос задал, так сразу и нашел… спасибо всем 🙂
Теперь у меня программно добавились 2 лишние кнопки печати, которые мне не нужны. Помимо тех что созданы на форме вручную. Вопрос: как мне их убрать?
В форме списка документа в процедуре ВыполнитьПодключаемуюКомандуПечати нужно поставить условие выполнения печати только, если документ проведен. Почему здесь не виден реквизит проведения документа?
Процедура Подключаемый_ВыполнитьКомандуПечати(Команда)
Объект=Элементы.Список.ТекущаяСтрока;
Если Объект.Проведен = Ложь Тогда
Сообщить(«Документ не проведен !!! Печать не возможна»);
Возврат;
КонецЕсли;
УправлениеПечатьюКлиент.ВыполнитьПодключаемуюКомандуПечати(Команда, ЭтаФорма, Элементы.Список);
КонецПроцедуры
Спасибо заранее!
(39) zmx,
думаю, тут лучше использовать Элементы.Список.ТекущиеДанные.Ссылка.Проведен, при условии, что в список выведена колонка Ссылка. Но я бы такие проверки перенес внутрь функций типа СформироватьПриказ
Be aware.. в новой БСП поменяли принцип подключения своих команд. Статью бы немного дополнить, так как в данном виде она утратила свою актуальность.
Вместо методов из «СтандартныеПодсистемы.Печать»
Следует использовать методы из «СтандартныеПодсистемы.ПодключаемыеКоманды»
Спасибо за предупреждение! (41)
От себя добавлю, что например в Бух КОРП 3.0.52.39 нужно в модуле: «ОбщийМодуль.УправлениеПечатьюПереопределяемый»
в процедуру:
добавить строку типа:
тогда, с учетом изменений описанных Вами, печать заработает!
(просто сам долго копался с этим)
С новыми обновами, новые веянья
Вызовы вида:
следует заменить вызовами:
Показать
более подробно читайте здесь
Добавление команд печати в Бухгалтерии 3.0 после релиза 3.0.52.35
в бухгалтерии корп 3.0 мне для того, чтобы появилась возможность печати в моем документе, пришлось в общем модуле «Управление печатью переопределяемый»
в эту процедуру добавить свой документ
Процедура ПриОпределенииОбъектовСКомандамиПечати(СписокОбъектов) Экспорт
там такие строки
и так далее — все документы
(45) Спасибо!!!!!
А если я хочу просто напечатать документ в своей самописанной конфе где нет никаких БСП и конструкторы печати теперь не работают. Что делать?
УНФ 1.6.5. БСП 2.3.1.53
в модуле УправлениеПечатьюСлужебныйКлиент
в процедуре ВыполнитьПодключаемуюКомандуПечатиПодготовкаОбъектовПечати
вываливается:
{ОбщийМодуль.УправлениеПечатьюСлужебныйКлиент.Модуль(125)}: Ошибка компиляции при вычислении выражения или выполнении фрагмента кода Результат = Вычислить(Обработчик);
по причине:
{(1,1)}: Переменная не определена (УправлениеПечатьюБПКлиент)
<<?>>УправлениеПечатьюБПКлиент.ВыполнитьКомандуПечати(ОписаниеКоманды)
Менял в Модуле Менеджера Документа
УправлениеПечатьюБПКлиент на УправлениеПечатьюКлиент и также на
Подключаемый_ВыполнитьКомандуПечати
всёравно ошибки, куда же копать?
(45) А в самом документе что нужно добавить?
(35)
не могу найти где эта галочка блин ….
(48) вы разобрались?
ТОже не могу для УНФ вывести
(51) давно это было, помню только что разобрался, а что именно сделал к сожалению уже не вспомню) Но конфигурация под рукой, могу сказать что где есть)