Отчет о движении денежных средств




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

    > первая хочет максимальной ясности при ежемесячном АХД, вторая не хочет раздувать вышеуказанный справочник (что я тоже поддерживаю) и мучаться правильно проставлять аналитику в документах и проводках.

    — т.е. типа из-за лени бухов — на тебе экономитс инструмент и бодайся..? типа так? хотя это первоочередная задача бухов — давать ясные и прозрачные цифры/отчеты по хоздеятельности предприятия.

    .

    так что позицию автора — не поддерживаю…

    Reply
  2. ZeBeR

    (1) позицию можно не поддерживать, а в жизни так бывает сплошь и рядом. И этот отчет поидее инструмент для облегчения жизни экономисту.

    Reply
  3. gtsy

    ОБРАБОТКА НЕ ЗАПУСКАЕТСЯ. КАК ЗАПУСТИТЬ

    Reply
  4. gtsy

    ОБРАБОТКА НЕ ЗАПУСКАЕТСЯ. КАК ЗАПУСТИТЬ ?

    Reply
  5. john-k

    Что-то с ней не так, не хотит работать и запоролена

    Reply
  6. dummy

    не работает. каких-то библиотек ей не хватает

    Reply
  7. SvSoft

    (3,4) Сорри, забыл указать, что файл precomp.dll нужно положить в папку с базой

    Reply
  8. SvSoft

    Перезалил архив, теперь чтобы установить отчет, его нужно просто распаковать в папку базы данных.

    Для тех кто на бронепоезде, повторяю: Не в ExtForms, не ещё куда-нибудь, а именно в папку БД.

    Reply
  9. SvSoft

    (1) любое мнение мне всегда важно, тем более от Че 🙂

    это всяко лучше чем, просто молча скачать. Так вот, могу ответить

    по этому поводу следующее:

    Я не знаю, как у вас, но у нас политика примерно такая:

    Бухи, в первую очередь отвечают за правильное ведение учета, именно бухгалтерского учета, и своевременную сдачу отчетности налоргам и прочим государевым людям, чтоб как можно меньше было у последних поводов и причин впаять нам штраф или какую-другую печаль.

    А вот подавать циферки руководству под «разными соусами» — это уже забота экономистов, финансистов и иже с ними…

    Reply
  10. mirco

    есть под восьмерку —реестр поступленийрасхода по ДДС

    Reply
  11. SvSoft

    (10) Это, типа, прорекламировал чтоль? 🙂

    Reply
  12. Olyunchik

    Расппаковала в папку базы данных а дальше … Можно для неумех поточнее?

    Reply
  13. SvSoft

    (12) А дальше — запускаем 1С Бухгалиерию и смотрим в Сервис->Дополнительные возможности. Должна появится строка — «Отчет по движению денежных средств». Открываем — пользуемся. В отчет встроен небольшой хелп — посмотрите.

    Reply
  14. mirco

    (11)нет 😀

    Reply
  15. Adoms

    Слабенький компьютер долго думает, а так все класс!

    Reply
  16. SvSoft

    (15) Ну тут ничем помочь не могу 😳

    Reply
  17. llg_44

    😀 И вправду долго формирует, но отлично, я лично +

    Reply
  18. SvSoft

    (17) Спасибо 😳 Вот все бы так…

    А то 150 скачавших, а комментов кот наплакал, про оценки я уж вообще молчу… Или всех настолько всё устраивает..?

    Reply
  19. chev

    Понравилось. Спасибо!!. Однозначно, +(плюс)

    Reply
  20. SvSoft

    (19) И вам спасибо 🙂

    Reply
  21. Арина10

    Здравствуйте! Никак не могу начать пользоваться вашим отчетом! скачала, открываю и вот какую информацию мне выдает:

    «компонента прикомпиляции недоступна!»

    а потом снизу в окошке:

    «ИнфСтрока

    Функция не обнаружена»

    я распаковала архив и открыла его по простому- файл-открыть

    Я что-то делаю не так? 😮

    Очень нужен ваш отчет и хочетсся вам за него плюсик постаивть 😉 ! Помоги пожалуйста!

    Reply
  22. Арина10

    Не могу воспользваться отчетом, пишет: компонента прикомпиляции недоступна 😮

    что это?

    Reply
  23. SvSoft

    (21,22) В описании читали «Для установки отчета — необходимо просто распаковать архив в папку с базой данных«? При этом всё будет работать нормально, а сам отчет попадет в папку ExtForms и будет доступен из меню «Сервис->Дополнительные возможности».

    Если же вы хотите «хранить» отчет в другом месте и запускать его оттуда же, то для корректной работы необходимо файл «precomp.dll» из архива положить в каталог с информационной базой, либо в каталог программы (по умолчанию находится «C:Program Files1Cv77BIN»)

    Reply
  24. okanat

    Не сработал,написал Поле агрегатного объекта не обнаружено (ДвиженияДенежныхСредств) Чем можно помочь (к сожалению в программировании 0)

    Reply
  25. SvSoft

    (27) А Вы на какой конфигурации его запускаете?

    Reply
  26. okanat

    🙁 1C 7.7 версия 3,6 .Это жена на ней работает ,просит иногда что то скачать и помочь. Не могу ведь перед ней в грязь лицом 😎

    Reply
  27. ooo-kiev

    думаю пора под 1С8 данный отчет переписать

    Reply
  28. SvSoft

    (30) c 1C8 не работаю ваапче пока…

    + посмотри (10), может устроит

    Reply
  29. Лена_Лена

    Спасибо, отчет понравился, то что нужно к годовой отчетности.

    Reply
  30. AB3012

    Спасибо, отчет понравился, то что нужно к годовой отчетности.

    Reply
  31. AB3012

    > первая хочет максимальной ясности при ежемесячном АХД, вторая не хочет раздувать вышеуказанный справочник (что я тоже поддерживаю) и мучаться правильно проставлять аналитику в документах и проводках.

    — т.е. типа из-за лени бухов — на тебе экономитс инструмент и бодайся..? типа так? хотя это первоочередная задача бухов — давать ясные и прозрачные цифры/отчеты по хоздеятельности предприятия.

    .

    так что позицию автора — не поддерживаю…

    Reply
  32. Доня

    Хороший отчет.

    Хорошо-бы в этот добавить еще одно субконто — Договоры

    Это было бы идеально

    Reply
  33. SvSoft

    (35) Куда добавить субконто???

    Еще одну колонку Корр. субконто 2 что ли?

    Reply

Leave a Comment

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