<?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='\
Спасибо, именно то, что я искала. Самой отчет сделать не получилось. Будем тестировать.
Идея отличная, спасибо. Потестим.
Плюс — наши расчётчики сказали, что им надо. Посмотрим, как работать будет.
(3) Моим расчетчикам уже пригодилась, суммы по пачкам и уволенным в 1 полугодии после исправления уплаты сели правильно.
Просто и внятно 🙂
А что если разница между сальдо и документом — 4 копейки, а начисленно за год меньше чем уплаченно на 10 т.р.?Вопрос снят. Туплю после ОРВИ.
💡 Обработка не открылась!!! файл скачивается без расширения!!!
(7) Значит, твой браузер по какой-то причине обрезал имя файла.
Добавь расширение .erf и открывай файл в 1С.
(ALL) вас случайно не напрягает то, что я в обработке использую немного непривычный порядок следования страховых взносов — сначала накопительную, а только затем страховую.
Обычно их порядок обратный — страховая, а затем накопительная.
Нужно ли исправлять? 🙂
Это несложно.
Огромное спасибо, помогло найти проблему, связанную с формированием уплаченной накопительной части за второе полугодие.
(ALL) вас случайно не напрягает то, что я в обработке использую немного непривычный порядок следования страховых взносов — сначала накопительную, а только затем страховую.
Немного напрягает 😀
За отчет Великое СПАСИБО!
СПАСИБО!! Отчет нужный, но в 1 квартале 2011 работает искаженно…Не показывает уплату за дек в январе. Если уже есть док по уплате за 2011год, то они попадают в 2010 в 1-е полугодие…. если есть возможность — исправьте.. 😀 .
Присоединяюсь к (12). Как только выправляется задолженность декабря 2010 проплатой в январе 2011, так этот документ бухается в 1 полугодие 2010 года, искажая сальдо за 1 полугодие 2010 года… и вообще тогда ничего не понять по остаточной задолженности. А уж если пытаться проверить 1 квартал 2011 года… лучше уж не делать, по той же причине: уплата за 1квартал 2011 года ложится в 1 полугодие 2010 года (!), вместо того, чтобы идти в хронологичном порядке вниз… и тогда сам чёрт ногу сломит в попытке разобраться в задолженности или переплате взносов.
В отчёте для 7-ки, который вдохновил, как я понял, на написание этого отчёта подобной несуразницы нет. Там всё работает корректно. Было бы очень желательно поправить описанную выше ошибку и привести отчёт в приличный вид. Действительно, отчёт очень актуален и нужен будет и в дальнейшем, конечно, если будет поправлена ошибка.
Рад бы был поставить плюс, но пока преждевременно…
Спасибо, очень помог отчет.=)
спасибо, достаточно полезный отчет!!
Действительно, полезный отчет, спасибо автору!
Автору зачет, поставил бухам, они счастливы)
Спасибо, что помогли убедить злых бухов! = )
Отчёт не учитывает разбивку 2011 года по кварталам.
Также непонятно изменение конечного сальдо при изменении даты начала периода.
Для получения информации начислено/уплачено/проверить ошибки начисления и т.п. детально по сотрудникам
http://infostart.ru/public/93830/
рекомендую свой отчет
Зы правда, уже платный
Присоединяюсь к (12). Как только выправляется задолженность декабря 2010 проплатой в январе 2011, так этот документ бухается в 1 полугодие 2010 года, искажая сальдо за 1 полугодие 2010 года… и вообще тогда ничего не понять по остаточной задолженности. А уж если пытаться проверить 1 квартал 2011 года… лучше уж не делать, по той же причине: уплата за 1квартал 2011 года ложится в 1 полугодие 2010 года (!), вместо того, чтобы идти в хронологичном порядке вниз… и тогда сам чёрт ногу сломит в попытке разобраться в задолженности или переплате взносов. В отчёте для 7-ки, который вдохновил, как я понял, на написание этого отчёта подобной несуразницы нет. Там всё работает корректно. Было бы очень желательно поправить описанную выше ошибку и привести отчёт в приличный вид. Действительно, отчёт очень актуален и нужен будет и в дальнейшем, конечно, если будет поправлена ошибка. Рад бы был поставить плюс, но пока преждевременно…
Так верно или неверно он работает в 2011г.?
Спасибо автору. Отчет оказался очень полезным.
отличная программа!!!
отличный отчетик, помог расчетчикам, автору респект!
(21) a31, Не верно!
В текущем состоянии отчет работает в целом верно, но есть небольшие недостатки:
1. не учитывается разбиение по кварталам, пока только по полугодиям.
2. некоторые периоды/суммы пляшут по разным полугодиям
3. также есть непонятки с задолженностью.
Мои бухи жалуются на эти недостатки, но активно пользуются.
Отчет будет исправлен в скором времени.
ЗУП 41.3 отчет не может быть прочитан текущей весией программы!!!
(27) LevSon, Скорее всего нужно открыть в конфигураторе, конвертировать
Спасибо, обработка очень помогла при распределении уплаченных страховых взносов по инвалидам!!!
Интересный отчет!
Огромное спасибо, помогло найти проблему, связанную с формированием уплаченной накопительной части за второе полугодие.
Отчёт не учитывает разбивку 2011 года по кварталам.
Также непонятно изменение конечного сальдо при изменении даты начала периода.
И меня странно- в 2011 году разбивка на 1 и 2 полугодия. Во втором висит январь, на январе оплата сентябрь.
Хотя все сведения в ЗУП забиты правильно и все отлично сдано в ПФР.
С 2011 годом отчет работает?
Учтены ли новые формы проводок по разноске оплаты ?
Спасибо, очень выручила обработка
Спасибо, пользуемся, очень нужная вещь.
У нас также Самим отчет сделать не получилось,
Хорошо есть добрые программеры!
оо спасибо за отчетик!!!
Смысл обработки понятен. Не могу понять только одного — где в документе «расчеты по страховым взносам» месяц начисления? В БП этот реквизит есть, но в ЗУП отсутствует напрочь.
Конфигурация: Зарплата и Управление Персоналом, редакция 2.5 (2.5.50.1)
(38) это еще что… в УПП 1.3.24.4 например, в документе «начисление страховых взносов» есть реквизит «месяц начислений», при проведении его, в регистр «Расчеты по страховым взносам» при записи ставиться начало года от этого «месяца начислений», а вот в документе «Расчеты по страховым взносам» — реквизит «месяц начислений» заполняется автоматом строкой «20100101» (датой отмены ЕСН) и ВСЕ!!!! далее при записи в регистр «Расчеты по страховым взносам» при записи ставиться начало года от этого «месяца начислений» (т.е. 01.01.2010!!!!!!) получается жестяная жесть!
Посмотрел в ЗУП, тоже самое…
ps может я не уловил мысли 1с по учету страховых взносов?
(39) sparklemal, это косяк настроек, проверь настройки программы насчет даты.
У меня в этом регистре (после проведения «Начисление страховых взносов» есть поле Дата операции, соответственно имеется ввиду месяц)
Обработочку счас потестим, спасибо. В описании очень многообещающе 🙂 Да и принцип стал понятен, а то бухи ввели все доки расчетов с видом Текущие платежи и спрашивают в чем дело.
О, для 77 как раз вариант удачный — там, как в черном ящике — где, что и откуда? «Простому» пользователю сложно было бы найти.
информацию надо в разрезе сотрудников в разрезе периодов, на мне помог