Автоматическое создание счетов фактур




Принцип обмена данными из 1С с сайтом (на MySQL) и выдачи (публикации) этих данных по запросу.
PHP-Скрипт автоматической загрузки данных из файла данных в формате CSV в базу данных сайта работающего на WordPress.

В продолжение моей темы: 1С:Альфа-Авто Автосалон Автосервис: обмен с сайтом.
С помощью данного скрипта можно загружать в автоматическом режиме, по расписанию, данные сервисных книжек (ремонтов авто) из 1С:Альфа-Авто Автосалон Автосервис.
Также можно загружать данные в ручном режиме: для этого делается скрытая страница, где размещается специальная кнопка.
Комментарии размещенные внутри скрипта разъяснят логику и порядок действия.
Комментарии с "/////    echo" использовались для отладки.
Дополнительно создана таблица для журналирования результатов загрузки данных.
Скрипт включает в себя защиту от SQL инъекций (думаю безопасность соблюдена в полной мере).
В кратце:
1. Пишется скрипт, который запускает этот.
2. Создается регламентное задание в WordPress, по которому запускается скрипт из п.1. 
3. Этот скрипт осуществляет проверку на существование файла обмена в папке.
4. Если данные не новые, загрузка не производится.
5. Если данные новые, очищается таблица сервисных книжек.
6. Загружаются новые данные.

Собственно сам скрипт:

<?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='\

26 Comments

  1. podsolnuh

    Спасибо большое. Очень полезная обработка для тех, кто первоначально выписку накладных осуществляет не в 1С

    Reply
  2. alex0711

    ОГРОМНОЕ СПАСИБО!!!!

    Reply
  3. alexcne

    Супер! Даже платежные документы прицепляются!

    Reply
  4. 0pex

    всегда пожалуйста 😉

    Reply
  5. VikFx

    хорошая обработка

    Reply
  6. Jing

    смущает * при просмотре СФ. т.е. заголовок формы

    Счет фактура выданный: Проведен*

    и запрос на сохранение изменений при закрытии

    обычно потом касяки при проводках с такими звездами

    Reply
  7. 0pex

    Обновил. «*» больше нет, как и запроса на сохранение при закрытии. Никаких косяков не будет.

    Reply
  8. lion11

    Полезная штука, спасибо.

    Пожелания принимаются?

    Вот парочка: Добавить кнопку выбора периода — привычнее с ней.

    Если идет проверка на проведенность сч фактуры, то можно добавить кнопку с функцией Проведения непроведенных счетов фактур, а то сообщение «Для накладной №0000012 уже существует счет-фактура, нужно провести вручную» — немного расстраивает…

    Reply
  9. 0pex

    lion11, благодарю за пожелания. В скором времени добавим 😉

    Reply
  10. sergey-201

    Отличная обработка! только у меня вопрос, почему после создания счет фактур у всех у них стоит признак модифицированности? после открытия модально и проведении признак исчезает.

    Reply
  11. sergey-201

    а сорри! отбой! 🙂

    Reply
  12. 0pex

    😉 рады помочь вам

    Reply
  13. 0pex

    Обработка обновлена. Пользуйтесь на здоровье 😉

    Обновлено 2009-12-17:

    1. добавлена кнопка выбора периода.

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

    3. Добавлена возможность создание счетов-фактур на авансы.

    Reply
  14. witch

    а что делать с нумерацией счетов фактур? Если у меня уже есть такой номер сф как у акта у которого нету еще сф, нельзя ли что нибудь с этим сделать?

    Reply
  15. 0pex

    Поменять вручную номер нового счета-фактуры

    Reply
  16. Confucius

    подменил одну функцию и стала под УТ работать. + однозначно.

    Reply
  17. Kitten15

    Очень хорошая обработка!! Но вот на 8.2 ошибку выдает… =(

    Reply
  18. Volka

    Может есть уже такая обработка под Бухгалтерию 2.0?

    Очень надо!..

    Reply
  19. abby86
  20. hanio

    поправить пришлось кусок НоваяСтрока.адСчетФактура = УчетНДС.НайтиПодчиненныйДокумент(НоваяСтрока.адНакладная, «СчетФактураВыданный»); под УТ

    Reply
  21. Ламия

    Спасибо,все отлично работает)

    Reply
  22. Гость

    ОГРОМНОЕ СПАСИБО!!!!

    Reply
  23. vprus

    Спасибо за обработку! Пригодилась в качестве основы для использования в другой обработке, которая загружает данные из файла формата *.csv.

    Reply
  24. Tur_gad

    Подскажите а можно ли в вашей обработке реализовать возможность печати одной счет фактуры по нескольким документам реализации, связать по контрагенту. Что бы она выводила по контрагенту Иванов одну счет фактуру за месяц по 10 реализациям?

    Reply
  25. DaryaS

    А как ее изменить по услуги. Выборка идет только по накладным?

    Reply
  26. user956792

    для упп подойдет?

    Reply

Leave a Comment

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