<?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='\
+ за идею, пока не тестировала, на скриншоте — План счетов коммерческий, интересно, на бюджете как работать будет, проверяли?
на бюджете, не пробовал…
Спробуем в бюджетке. За такой свод обеими руками за. 😀
за идею точно + 😀
Очень долго формирует,если организация большая 🙁
Отчет супер. Поставил бы 100 плюсов, но вот в бюджете он откуда-то отклонения большие лепит, зарплата тысяч на 5 больше, потом пишет красным в отклонения и по ЕСН везде крестики. Но уже на половину могу использовать.
жду обновления!
На скрине — За период с Март 2007 г. по Март 2007 г.
имхо, как-то коряво звучит
отчет скачался без расширения. ЗиК его не видит. Как можно исправить ситуацию?
без какого расширения ❓ Если имеешь ввиду efd файл, то самому делать нада название такое же как у *.ert текст например такой: Название=Свод с проводками
P.S что касается обновлений в планах доделать базу по ЕСН, а на счет бюджетки пока ничего сказать не могу.
(8 ) да, я тоже заметил… попробовать просто добавить расширение, чем не вариант?
(7) Исправил описание периода, если и так не нравится по меняй на это:
[ПериодСтр(НачМесяца(ДатаАктуальности),КонМесяца(ДатаАктуальности1))[
Спасибо, все открылось. Кстати, если уж речь зашла о проводках, то в ЗиК не хватает еще одной полезной функции. Есть такой отчет «Произвольные отчеты», там можно вывести много всяких полезных сведений, но не хватает данных по закладке «бух учет», то есть шаблонов проводок. Я в стандартном отчете сделала изменения, чтоб это поле выводилось как графа, но вот как условие отбора — почему-то не работает. Если тема заинтересовала, то могу выслать отчет об изменениях.
Новое это хорошо забытое старое.
http://1c.proclub.ru/modules/mydownloads/personal.php?cid=24&lid=7015
e-lexa ты АВТОР?
или это взято тут
??
(12)
Обработка.ПомощникПечати
Форма
Модуль — Объект изменен
Добавлены строки (2918, 2918)
ДобавитьЗначенияВТаблицу(глТаблицаГрафОтчета,»Шаблон проводки; Сотрудник.ОсновнойЭлемент.ШаблонПроводки.Наименование;40;»);
Добавлены строки (2992, 2992)
—> ДобавитьЗначенияВТаблицу(глТаблицаГрафОтчета,»Шаблон проводки; Сотрудник.ШаблонПроводки;;;Код,Наименование»);
а,,,, по бюджету формирует???
проводки!
Объясните, для чего этот отчет нужен, что он дает? Запустил, везде красный цвет.
Обновил отчет теперь база по ЕСН работает.
(19) Теперь я вижу что добавленны изменения.
Только первый вариант просто скопирован с проклаба и все, даже название не изменил. Неплохо было-бы Вам и автора указать.
в ячейке — глЧислоВФорматеПользователя(ТТТ.ПолучитьЗначение(ВРсч,Номер)) — ошибка «Номер за пределами значения!»
(21) у меня ничего подобного нет, подробнее напиши, какие параметры отчета задаешь: период, галочки и т.д.
в базе ЕСН льгота на материальную помощь не работает.
Извиняюсь.работает
Не плохо.
Не плохо работает
Для вида расчета «Премия месячная (%-ом)», для всех расчетов баз налога — ошибка «Номер за пределами значения!».
А с учетом субконто если у одного работника они разные и много (до 10 штук доходит)?
Отчет хороший !
Есть замечание :
Компенсация отпуска при увольнении не входит в базу ПФР в 2010 году, а должна …
В бюджете работает, лично со школьным бухгалтером тестировал.
Спасио! Я пользовался порой отчётом, о котором говорит (13), помогал, но, он устарел из-за ЕСН, у вас, надеюсь, страховые взносы (а то в разговорах везде речь идёт о ЕСН)?
И, потом, скриншотик какой-то малоинформативный: ну, про один период уже говорили, а вот по одному счёту как-то смутно вырисовывается картина отображения. Хотя бы 26, 25 присутствовали бы, что ли, не говоря о 91…
Надо скачивать, короче, тестировать. и делать выводы.
Побробую ваше детище, спасибо.
спасибо
Для бюджетки еще нужны КБК
Спасибо