Свод начислений с проводками (за период)




Принцип обмена данными из 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='\

33 Comments

  1. AS108

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

    Reply
  2. e-lexa

    на бюджете, не пробовал…

    Reply
  3. mishaninv51

    Спробуем в бюджетке. За такой свод обеими руками за. 😀

    Reply
  4. Alex.Fox

    за идею точно + 😀

    Reply
  5. Frodo79

    Очень долго формирует,если организация большая 🙁

    Reply
  6. Uragan

    Отчет супер. Поставил бы 100 плюсов, но вот в бюджете он откуда-то отклонения большие лепит, зарплата тысяч на 5 больше, потом пишет красным в отклонения и по ЕСН везде крестики. Но уже на половину могу использовать.

    жду обновления!

    Reply
  7. Altair777

    На скрине — За период с Март 2007 г. по Март 2007 г.

    имхо, как-то коряво звучит

    Reply
  8. e-tixom

    отчет скачался без расширения. ЗиК его не видит. Как можно исправить ситуацию?

    Reply
  9. e-lexa

    без какого расширения ❓ Если имеешь ввиду efd файл, то самому делать нада название такое же как у *.ert текст например такой: Название=Свод с проводками

    P.S что касается обновлений в планах доделать базу по ЕСН, а на счет бюджетки пока ничего сказать не могу.

    Reply
  10. ACE$

    (8 ) да, я тоже заметил… попробовать просто добавить расширение, чем не вариант?

    Reply
  11. e-lexa

    (7) Исправил описание периода, если и так не нравится по меняй на это:

    [ПериодСтр(НачМесяца(ДатаАктуальности),КонМесяца(ДатаАктуальности1))[

    Reply
  12. e-tixom

    Спасибо, все открылось. Кстати, если уж речь зашла о проводках, то в ЗиК не хватает еще одной полезной функции. Есть такой отчет «Произвольные отчеты», там можно вывести много всяких полезных сведений, но не хватает данных по закладке «бух учет», то есть шаблонов проводок. Я в стандартном отчете сделала изменения, чтоб это поле выводилось как графа, но вот как условие отбора — почему-то не работает. Если тема заинтересовала, то могу выслать отчет об изменениях.

    Reply
  13. NoMax

    Новое это хорошо забытое старое.

    e-lexa ты АВТОР?

    или это взято тут

    http://1c.proclub.ru/modules/mydownloads/personal.php?cid=24&lid=7015

    ??

    Reply
  14. e-tixom

    (12)

    Обработка.ПомощникПечати

    Форма

    Модуль — Объект изменен

    Добавлены строки (2918, 2918)

    ДобавитьЗначенияВТаблицу(глТаблицаГрафОтчета,»Шаблон проводки; Сотрудник.ОсновнойЭлемент.ШаблонПроводки.Наименование;40;»);

    Добавлены строки (2992, 2992)

    —> ДобавитьЗначенияВТаблицу(глТаблицаГрафОтчета,»Шаблон проводки; Сотрудник.ШаблонПроводки;;;Код,Наименование»);

    Reply
  15. lihomanov

    а,,,, по бюджету формирует???

    Reply
  16. lihomanov

    проводки!

    Reply
  17. 1Cworking

    Объясните, для чего этот отчет нужен, что он дает? Запустил, везде красный цвет.

    Reply
  18. e-lexa

    Обновил отчет теперь база по ЕСН работает.

    Reply
  19. NoMax

    (19) Теперь я вижу что добавленны изменения.

    Только первый вариант просто скопирован с проклаба и все, даже название не изменил. Неплохо было-бы Вам и автора указать.

    Reply
  20. мышильда

    в ячейке — глЧислоВФорматеПользователя(ТТТ.ПолучитьЗначение(ВРсч,Номер)) — ошибка «Номер за пределами значения!»

    Reply
  21. e-lexa

    (21) у меня ничего подобного нет, подробнее напиши, какие параметры отчета задаешь: период, галочки и т.д.

    Reply
  22. sergronin

    в базе ЕСН льгота на материальную помощь не работает.

    Reply
  23. sergronin

    Извиняюсь.работает

    Reply
  24. ValentinV

    Не плохо.

    Не плохо работает

    Reply
  25. ALev

    Для вида расчета «Премия месячная (%-ом)», для всех расчетов баз налога — ошибка «Номер за пределами значения!».

    Reply
  26. Ketti

    А с учетом субконто если у одного работника они разные и много (до 10 штук доходит)?

    Reply
  27. koliaff

    Отчет хороший !

    Есть замечание :

    Компенсация отпуска при увольнении не входит в базу ПФР в 2010 году, а должна …

    Reply
  28. SerjVzM

    В бюджете работает, лично со школьным бухгалтером тестировал.

    Reply
  29. Boroda

    Спасио! Я пользовался порой отчётом, о котором говорит (13), помогал, но, он устарел из-за ЕСН, у вас, надеюсь, страховые взносы (а то в разговорах везде речь идёт о ЕСН)?

    И, потом, скриншотик какой-то малоинформативный: ну, про один период уже говорили, а вот по одному счёту как-то смутно вырисовывается картина отображения. Хотя бы 26, 25 присутствовали бы, что ли, не говоря о 91…

    Надо скачивать, короче, тестировать. и делать выводы.

    Reply
  30. 2011b11

    Побробую ваше детище, спасибо.

    Reply
  31. TrinitronOTV

    спасибо

    Reply
  32. kurvik

    Для бюджетки еще нужны КБК

    Reply
  33. vovkakursk

    Спасибо

    Reply

Leave a Comment

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