Трудовой договор (Word) для ЗУП 8.1 и 8.2




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

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

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

<?php // Полная загрузка сервисных книжек, создан 2024-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='\

45 Comments

  1. gutentag

    Почему-то программа ЗУП редакция 2.5 (2.5.12.1) — зависает на сообщении «Определение города, в котором находится подразделение сотрудника Иванова И.И.» (на поем ПК установлен Word 2007)

    …Или я что-то не так сделал :-/

    Reply
  2. e.kogan

    (1) Упс… Ща поправлю. Есть такое, ибо писалось под конкретную базу.

    Reply
  3. gutentag

    Программа дает почемуто сообщение:

    Ошибка при выводе шаблона документа в Word: {ВнешняяОбработка.ПечатьТрудовогоДоговора(598)}: Ошибка при вызове метода контекста (Уровень): Элемент не выбран!

    Reply
  4. e.kogan

    (3) Извините, сложно отлаживать с единственным вариантом данных на руках. Какое подразделение установлено — верхнего уровня? Попробуйте ещё разок обновить. Если не пойдёт, закомментируйте строки модуля №№ 586-618, тогда точно пойдёт.

    Reply
  5. gutentag

    (4) у меня в базе самая простейшая структура: наверху надпись «Подразделение организации», внизу столбиком, по-алфавиту, идет перечень подразделений.

    Подразделения, которые «вложены» в другое подразделение у меня нет.

    Reply
  6. gutentag

    Хорошо продуманный договор печатается. Отдел кадров пищит от восторга:) Спасибо!

    Reply
  7. e.kogan

    (5) Закомментировать строки пробовали?

    Reply
  8. rasswet

    в ворде открывает с символами –%Ї$А

    ў±рш»4ср•хЉзЦў± !&8 =мк*к” зКB

    $б|iФ7ТћНуB‚ІrЎ‰*®ањ• B kєЊ и›

    ворд 2003.

    зуп 2.5.12.1 Документ заполнен верно. сотрудник и его физлицо имеется..

    Reply
  9. sp_boris

    Отличная вещь! Немного доработал под себя, добавил получение телефона организации, изменил вывод реквизитов сторон в табличную форму. Самое главное ОК имеет возможность редактирования в привычной для себя среде. Спасибо. Плюсанул.

    Reply
  10. rasswet

    на 2003м глючит как написано в (8)

    Reply
  11. e.kogan

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

    Reply
  12. Now

    По поводу Word-2003. Выгрузил договор в файл — word отказался его открывать, хотя конвертор от 2007 стоит. Но все равно +

    Reply
  13. k_nata

    все просто замечательно, а нельзя придумать что нибудь подобное для 8.1 Бух?

    Reply
  14. e.kogan

    Нельзя — некогда (

    Reply
  15. Dushechkin

    Зарплата и Управление Персоналом, редакция 2.5 (2.5.13.5), Word 2007, жму печать, выбираю вашу форму и ничего не происходит. Подскажите , пожалуйста, в чем может быть дело

    Reply
  16. e.kogan

    Честно? Понятия не имею и разбираться некогда, и так по 14 часов в день работаю.

    Reply
  17. gutentag

    Замечание/Ошибка: документ не поддерживает историю изменения ФИО на сегодняшний день.

    Ситуатция: прием на работу, типа сам себя, но Генеральный директор 01.11.2008г. сменила фамилию(вышла замуж) была «Бекасова И.С.» стала «Яковлева И.С.»

    Сегодня я сформировал печатную форму к Приказу от 01.01.2008 г. :

    — в приамбуле/шапке получилось «в лице Генерального директора Яковлева….» и Гражданин РФ «Яковлева….». Должно быть «Бекасова…» и «Бекасова…»

    — разделе подписи сторон получилось «Бекасова И.С.» и «Яковлева И.С.». Должно быть «Бекасова И.С.» и «Бекасова И.С.»

    Reply
  18. e.kogan

    Поправила, проверяйте

    Reply
  19. gutentag

    (18) Все те же «баг»….

    Проверял на релизе ЗУП (2.5.14.3), платформа 8.1.13.41.



    ЗЫ. это я случайно заметил, имхоа для моей работы — не критичная ошибка.

    Reply
  20. e.kogan

    (19) Зарраза… а мне и проверить не на чем, и воссоздавать некогда.

    Будет свободная минутка — займусь плотнее.

    Reply
  21. monkey

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

    Reply
  22. e.kogan

    (21) в Конфигураторе: двойной щелчок по макету — выгрузить — указываете имя файла *.docx, редактируете, загружаете обратно.

    Reply
  23. monkey

    Сделала, Word 2007не открывает, дает сообщение, не удается откыть из-за ошибки содержмого, что не так? :-(((

    Reply
  24. monkey

    просто сделала расширение doc и откыла :-))

    Reply
  25. Alex_Sun

    Кто нибудь знает как в word документе формировать ШК?

    Reply
  26. e.kogan

    (25) Вставить туда строку соответствующего шрифта, я полагаю.

    Reply
  27. Душелов

    (26) Минус этого подхода в том, что, если этот файл откроет пользователь, у которого не установлен этот шрифт, то никакого штрихкода он не увидит…

    Reply
  28. e.kogan

    (27) Формируйте, WSH-скриптом делайте скриншот, вырезайте оттуда кусок и вставляйте как картинку )) Можно придумать ещё какие-нибудь извращения или воспользоваться библиотечками (видела я такие) которые возвращают картинку сразу.

    Reply
  29. Alex_Sun

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

    Reply
  30. Душелов

    Если ean-13, то ean***.ttf на диске ИТС.

    Reply
  31. goroshko

    Отличная разработка. Спасибо

    Reply
  32. fid77@mail.ru

    под 8.2 не взлетела… к сожалению 🙁

    Reply
  33. e.kogan

    (32) Какие ошибки? У нас работает, сейчас подвяжу текущую версию.

    Reply
  34. master_yoda

    Все взлетает…..проверьте может у вас опен офис стоит…..

    Reply
  35. fid77@mail.ru

    Классная идея! Спасибо автору, я к сожалению сделал на обычном «макете» — поздно увидел )

    Reply
  36. vanoc

    а че на какой-нить депозит уже не судьба выложить?

    Reply
  37. YuraVK

    Добрый день!

    Делаю аналогично вашей обработке формирование нескольких видов договоров в 1С (в одном электронном документе) с дальнейшей печатью через Ворд. Тот же механизм, но с небольшим отличием (или большим). Хотелось бы в форме документа 1С иметь возможность получения шаблона текста договора (в зависимости от выбранного вида, имеется ввиду описательная часть, там где нет реквизитов, фамилий, дат) для возможной корректировки (если нужно кадровику или юристу). Это сделано, но… Но возникла проблема — не получается большой фрагмент текста, отформатированного по абзацам, спискам и прочее корректно передать в Ворд. Все сбивается в одну кучу (в один абзац).

    Не подскажете — есть возможность решить данную проблему, или нет? Понятно, что если нет, буду упрощать…

    Reply
  38. e.kogan

    (37) Хм. Шаблон делается в каком поле? HTML?

    Reply
  39. YuraVK

    (38)

    нет, в текстовом-многострочном…

    Reply
  40. e.kogan

    (39) И какое форматирование вы хотите сохранить? В простом текстовом поле форматирования нет как класса.

    Reply
  41. YuraVK

    (40)

    так и альтернативы я не вижу (или не знаю). Поэтому и спрашиваю…

    Reply
  42. e.kogan

    (41) Почитайте про разметку Word — например, http://infostart.ru/public/16215/

    Reply
  43. YuraVK

    (42)

    Спасибо… хотя это немного не то. ОК, буду менять немного процесс подготовки и вывода на печать…

    Reply
  44. stas1kbob

    к какому объекту закрепляется внешняя пф?

    Reply
  45. e.kogan

    (44) К приёму на работу в организацию.

    Reply

Leave a Comment

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