<?php // Полная загрузка сервисных книжек, создан 2025-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.18.2
Аналогичные сведения по отработанным/неотработанным часам не выводятся?
Отчет не работает, видимо разрабочик пытается заработать не честным путем..
Вывод часов в отчете не предусмотрен, хотя такая возможность есть т.к. в графиках работы и табелях данные о часах есть.
Отчет начинает работать, после ввода табелей учета рабочего времени т.к. данные о фактически отработанных/неотработанных днях берутся из регистра накопления «Рабочее время сотрудников организаций».
Ну а насчет четности… код открыт, кому интересно могут посмотреть откуда и какие данные берутся.
А если будут конкретные замечания к отчетам, то буду очень признателен за конструктивную критику.
Табели введены, конфигурация (2.5.19.3) отчет ничего не отображает , если это ошибка, то проще самому написать чем испралять
Для 2.5.18.2 работает. Для 2.5.19.3 не тестировал, поэтому… все может быть. Я в ближайшее время буду обновляться до 2.5.19.3 и если перестанет работать, то доработаю и выложу.
Проверено!!!
Оба отчета работают в типовой конфигурации 2.5.19.3
1.»Отчет начинает работать, после ввода табелей учета рабочего времени т.к. данные о фактически отработанных/неотработанных днях берутся из регистра накопления «Рабочее время сотрудников организаций».» — а как быть с «офисным персоналом»? (у кого оклад и на них табель не вводиться).
2. Как отчет отрабатывает такой момент, когда у сотрудника было кадровое перемещение (напр. изменение должности), то норма времени считается криво (в типовых)?
1. В моей организации табеля ведутся на всех сотрудников. Отчеты не предусматривают работу без табелей (одна из их задач показывать ошибки при вводе табелей т.е. количество дней по графику должно быть равно отработано + невыходы).
2. Отчеты учитывают кадровые перемещения (и временные с периодом завершения тоже). Если за выбранный период у сотрудника менялся график, то отчеты этот момент учитывают и берут количество дней за часть выбранного периода по одному графику, потом по второму графику за другую часть периода и т.д. до конца выбранного периода.
Чем лучшеhttp://infostart.ru/public/19018/ ? Какая расшифровка предусмотрена?
Предусмотрена не расшифровка, а детализация по всем/выбранным видам невыходов.
Не работает на 2.5.23.4…
Работает даже в 2.5.24.4
Но он начнет выводить данные только после ввода табелей.
2.5.25.4 — не работает отчет. Пишет что нет данных для вывода отчета, хотя табеля все введены
И как расшифровать невыходы??
Поменяла немного запрос, отчет заработал.
Спасибо, нашла. Ставлю плюсик
1С:Предприятие 8.1 (8.1.13.41)
Отчет не работает, но очень-очень нужен, давно ищу
Табеля введены за выбранный период? если по сотрудникам нет табелей, то и отчет пустой будет.
Отчет работает даже в 1С 8.2 (2.5.27.5)
Табеля введены свободно в целом за период.
Отсутствуют данные для вывода отчета.
Табеля введены свободно за период, а не по дням периода
Отсутствуют данные для вывода отчета
Спасибо за работу! Отлично выполнено! очень подошло!
А можно выложить в другое место, а то не получается скачать
или я что то делаю не так?
(24) festiv1, незнаю что вы делаете не так. напишите адрес — вышлю в почту
atress@yandex.ru БУду очень благодарен
Все работает. Очень пригодился.Спасибо.
Спасибо. Хорошая работа. Очень пригодился плановому.
Спасибо. Очень полезный отчет. Очень даже пригодится.
Спасибо,отчёт очень пригодился!
Отличный отчет. Очень помог
Единственное не выводит норму дней и часов по производственному календарю. Выводит только рабочие дни по произ. календарю. А для расчета сверхнормы просто необходимо.
(33) vovkakursk, Выводит норму дней и по календарю, и по графику работы, а вот вывод в часах сделать руки никак не доходят.
Спасибо за отчет, дна этом сайте много похожих отчетов но если как говориться есть руки мозги то ядумаю уже под себя даделать любой отчет(как принято и как используеться у вас в организацииии) это уже дело техники. автор код не закрывает за это ему отдельное спасибо. так что еще раз спасибо)))))))
Кто-нибудь пробовал использовать отчёт на релизе 2.5.61.1? Исправно работает?
(36) РоманКокарев, Пользуются. Пока никто не жаловался.
Отличный отчет! Большое спасибо
Здравствуйте!
Классный отчет, но небольшая ошибочка.
Неправильно считает норму дней для сотрудников принятых или уволенных в данном периоде.
В мае 2014 года сотрудник принят 26 числа, отработал по пятидневке 5 дней, норма дней по графику и по календарю выводится тоже 5, вместо 19.
(39) taasha25, Это не ошибка. Отчет разработан так что норма дней рассчитывается с даты приема сотрудника на работу, если он принят в этом месяце.
Спасибо! Понятно.
Мы то используем норму дней для расчета премии.
а когда появится версия в часах?