<?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='\
Почему-то программа ЗУП редакция 2.5 (2.5.12.1) — зависает на сообщении «Определение города, в котором находится подразделение сотрудника Иванова И.И.» (на поем ПК установлен Word 2007)
…Или я что-то не так сделал :-/
(1) Упс… Ща поправлю. Есть такое, ибо писалось под конкретную базу.
Программа дает почемуто сообщение:
Ошибка при выводе шаблона документа в Word: {ВнешняяОбработка.ПечатьТрудовогоДоговора(598)}: Ошибка при вызове метода контекста (Уровень): Элемент не выбран!
(3) Извините, сложно отлаживать с единственным вариантом данных на руках. Какое подразделение установлено — верхнего уровня? Попробуйте ещё разок обновить. Если не пойдёт, закомментируйте строки модуля №№ 586-618, тогда точно пойдёт.
(4) у меня в базе самая простейшая структура: наверху надпись «Подразделение организации», внизу столбиком, по-алфавиту, идет перечень подразделений.
Подразделения, которые «вложены» в другое подразделение у меня нет.
Хорошо продуманный договор печатается. Отдел кадров пищит от восторга:) Спасибо!
(5) Закомментировать строки пробовали?
в ворде открывает с символами –%Ї$А
ў±рш»4ср•хЉзЦў± !&8 =мк*к” зКB
$б|iФ7ТћНуB‚ІrЎ‰*®ањ• B kєЊ и›
ворд 2003.
зуп 2.5.12.1 Документ заполнен верно. сотрудник и его физлицо имеется..
Отличная вещь! Немного доработал под себя, добавил получение телефона организации, изменил вывод реквизитов сторон в табличную форму. Самое главное ОК имеет возможность редактирования в привычной для себя среде. Спасибо. Плюсанул.
на 2003м глючит как написано в (8)
Ну нет у меня 2003го ворда на работе (только уродский 2007-й), а дома нет этой конфы. Проверить не могу, но есть подозрение, что это косяк 2007-го, потому как я шаблон сохраняла в режиме совместимости и по идее работать с любой версией должен.
По поводу Word-2003. Выгрузил договор в файл — word отказался его открывать, хотя конвертор от 2007 стоит. Но все равно +
все просто замечательно, а нельзя придумать что нибудь подобное для 8.1 Бух?
Нельзя — некогда (
Зарплата и Управление Персоналом, редакция 2.5 (2.5.13.5), Word 2007, жму печать, выбираю вашу форму и ничего не происходит. Подскажите , пожалуйста, в чем может быть дело
Честно? Понятия не имею и разбираться некогда, и так по 14 часов в день работаю.
Замечание/Ошибка: документ не поддерживает историю изменения ФИО на сегодняшний день.
Ситуатция: прием на работу, типа сам себя, но Генеральный директор 01.11.2008г. сменила фамилию(вышла замуж) была «Бекасова И.С.» стала «Яковлева И.С.»
Сегодня я сформировал печатную форму к Приказу от 01.01.2008 г. :
— в приамбуле/шапке получилось «в лице Генерального директора Яковлева….» и Гражданин РФ «Яковлева….». Должно быть «Бекасова…» и «Бекасова…»
— разделе подписи сторон получилось «Бекасова И.С.» и «Яковлева И.С.». Должно быть «Бекасова И.С.» и «Бекасова И.С.»
Поправила, проверяйте
(18) Все те же «баг»….
Проверял на релизе ЗУП (2.5.14.3), платформа 8.1.13.41.
—
ЗЫ. это я случайно заметил, имхоа для моей работы — не критичная ошибка.
(19) Зарраза… а мне и проверить не на чем, и воссоздавать некогда.
Будет свободная минутка — займусь плотнее.
Скажите пожалуйста, макет в виде двочных данных как то можно править, текст изменить или это необратимый процес?
(21) в Конфигураторе: двойной щелчок по макету — выгрузить — указываете имя файла *.docx, редактируете, загружаете обратно.
Сделала, Word 2007не открывает, дает сообщение, не удается откыть из-за ошибки содержмого, что не так? :-(((
просто сделала расширение doc и откыла :-))
Кто нибудь знает как в word документе формировать ШК?
(25) Вставить туда строку соответствующего шрифта, я полагаю.
(26) Минус этого подхода в том, что, если этот файл откроет пользователь, у которого не установлен этот шрифт, то никакого штрихкода он не увидит…
(27) Формируйте, WSH-скриптом делайте скриншот, вырезайте оттуда кусок и вставляйте как картинку )) Можно придумать ещё какие-нибудь извращения или воспользоваться библиотечками (видела я такие) которые возвращают картинку сразу.
Не нашел я такой шрифт. пользователь будет конкретный. у него будет установлено все что душе угодно лишь бы этот механизм работал.
Если ean-13, то ean***.ttf на диске ИТС.
Отличная разработка. Спасибо
под 8.2 не взлетела… к сожалению 🙁
(32) Какие ошибки? У нас работает, сейчас подвяжу текущую версию.
Все взлетает…..проверьте может у вас опен офис стоит…..
Классная идея! Спасибо автору, я к сожалению сделал на обычном «макете» — поздно увидел )
а че на какой-нить депозит уже не судьба выложить?
Добрый день!
Делаю аналогично вашей обработке формирование нескольких видов договоров в 1С (в одном электронном документе) с дальнейшей печатью через Ворд. Тот же механизм, но с небольшим отличием (или большим). Хотелось бы в форме документа 1С иметь возможность получения шаблона текста договора (в зависимости от выбранного вида, имеется ввиду описательная часть, там где нет реквизитов, фамилий, дат) для возможной корректировки (если нужно кадровику или юристу). Это сделано, но… Но возникла проблема — не получается большой фрагмент текста, отформатированного по абзацам, спискам и прочее корректно передать в Ворд. Все сбивается в одну кучу (в один абзац).
Не подскажете — есть возможность решить данную проблему, или нет? Понятно, что если нет, буду упрощать…
(37) Хм. Шаблон делается в каком поле? HTML?
(38)
нет, в текстовом-многострочном…
(39) И какое форматирование вы хотите сохранить? В простом текстовом поле форматирования нет как класса.
(40)
так и альтернативы я не вижу (или не знаю). Поэтому и спрашиваю…
(41) Почитайте про разметку Word — например,http://infostart.ru/public/16215/
(42)
Спасибо… хотя это немного не то. ОК, буду менять немного процесс подготовки и вывода на печать…
к какому объекту закрепляется внешняя пф?
(44) К приёму на работу в организацию.