Учёт ОС и как "Я" его понимаю …




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

25 Comments

  1. Alraune

    Красный шрифт на белом фоне очень тяжело читается. Лучше бы жирным выделяли, что ли

    Reply
  2. Шёпот теней

    (1) … редактировал … редактировал …

    хотел всю статью сделать КРАСИВО — как у тебя это плучается … форматировал — форматировал … плюнул — сунул файлом … ужжж … вот …

    … как то всё само форматируется … вОООбщем чё-то я не понял … ((( …

    кому интересна данная тема и данный текст — рекомендую скачать приложенный файл (около 3 мБ) …

    … вот …

    Reply
  3. Шёпот теней

    спасибо Alraune … источник примеров из файла находится тут: http://www.intuit.ru/department/office/acc1c8/9/

    файл можно теперь и не скачивать …

    … вотВЕДЬвот …

    Reply
  4. Арчибальд

    При всем богатстве сведений (22 регистра!) нужные (производственному предприятию) отсутствуют. А нужно заводу планировать профилактический ремонт и учитывать факт ремонта, различая плановые и аварийные ремонты, в т.ч., корректировать план ремонта, а также прогнозировать модернизацию и замену ОС.

    Reply
  5. Шёпот теней

    (4) … проблема ОС как и учёт ЗП … в отличие от УУ … почему-то остался НЕзметным для управленцев предприятиями … тема никак и нигде не поднимается и не обсуждается … типа 1С считает и лаТно …

    … это очень сложно и не однозначно … взять хотя бы учёт рабочей одежды (спецодежда) …

    … на многих ли предприятиях есть бухгалтер по налоговому учёту …

    … вот …

    Reply
  6. KapasMordorov

    В плане счетов есть еще счета 03, 001, 011 — работа с ними не автоматизирована, но учет можно вести, в отчетности учитываются.

    Reply
  7. Шёпот теней

    (4) … «профилактический ремонт и учитывать факт ремонта, различая плановые и аварийные ремонты» — видимо можно учитывать как модернизацию … в самом простом случае …

    … а вот «прогнозировать модернизацию и замену ОС» — тут видимо надо что-то дополнительное или отдельное …

    .. а как у вас … ? … есть ли решение и какое … ? … поделись …

    … вот …

    Reply
  8. Арчибальд

    (5) Касательно спецодежды — я почти что краевед 😀 http://infostart.ru/public/18686/

    (6) Счет 003 — вообще очень интересная пЕсня…

    Reply
  9. Шёпот теней

    … и что же там за песня с 003 … ? …

    Reply
  10. Арчибальд

    (7) У нас предписанная конфа Бух 7.7. ред. 4.2. извращенная. Там даже модернизации ОС нет. Сделали учет ремонтов — самое начало, отнесение затрат на конкретное ОС, но проект заглох при очередной смене руководства. До прогнозирования так и не добрались 🙁

    Reply
  11. Шёпот теней

    (10) … видимо переключились на УУ … ))) … вот …

    … по поводу 003 … читаю …

    Reply
  12. Арчибальд

    (9) Я имел в виду 03 — грубо говоря, ОС напрокат. Песня начинается, когда из проката возвращают поломанный станок. Опять же, с ремонтом — и с получением компенсации от виновного…

    Reply
  13. Арчибальд

    (11) Точный диагноз 😀

    Reply
  14. Шёпот теней

    (12) … видимо тут будут внереализационными расходы/доходы … с проблемами как связть сумму за ремонт с налогами чтобы «не пролететь» …

    … видимо проще страховать … ? … ! …

    (В соответствии с п.8 ст.250 НК РФ безвозмездно полученное имущество включается в состав доходов по рыночной стоимости, но не ниже остаточной стоимости — по амортизируемому имуществу, и затрат на производство (приобретение) — по товарам (работам, услугам) …

    … вот …

    Reply
  15. Арчибальд

    (14) Так с ходу и не скажешь… Исследовать требуется…

    Reply
  16. ildarovich

    (4)(7) Подсистема называется ТОИР (Технология обслуживания и ремонта оборудования). Некоторые ее функции есть в УПП. Есть и отдельные специализированные конфигурации.

    Reply
  17. Арчибальд

    (16) Да я в курсе 🙁

    Reply
  18. Шёпот теней

    (16) … какова же её стоимость … ??? . вотИнтересно …

    + масштаб предприятия для оптимального и экономического выгодного внедрения … читаю — что-то пока одни глобальные проекты и предприятия … вот …

    цены тут

    … и кто этим пользовался интерсно … какие мнения … ?

    … пробовали мы тут «расширение для карманных компьютеров» — офанарели и забросили (деньги на ветер) … вот …

    Reply
  19. Арчибальд

    (18) Где-то так вот

    Reply
  20. Шёпот теней

    нет ни буйной рекламы … ни реакции форумов … одна стандартная «описание конфигурации» … видимо «заБОЙный» получился продукт …

    .. из серии автоматизации расписаний — коп штука да рубль перевоз …

    … ужжжВОТжжжу …

    Reply
  21. Alef

    (20) ТОиР пользуемся год, многое пришлось допилить, конечно, но в целом устраивает.

    Reply
  22. ildarovich

    (18) Расширение для карманных компьютеров — классная штука, когда освоишь. Очень «дешево» (в смысле затрат времени) с нуля получаются неплохие мини-1С на КПК для офф-лайн использования, синхронизируемые с основной базой. Все работает!

    А под 8.2 для УТ11 и готовые конфигурации есть.

    Reply
  23. Шёпот теней

    (22) … понятно … что «сам дурак» … кто жжжж спорит — особенно «когда освоишь» …

    … в целом:

    1. я бы не согласился с вашим мнением — ибо стоимость есть абсолютная а есть относительная …

    2. моё отношение к данному продукту основано на личном мнении и мнении товарищей из различных форумов …

    3. всё познаётся в сравнении — есть программы в разы лучше — например «Агент Плюс» !!! … рекомендую всем кто будет заниматься данной проблемой, проблемой КПК и 1С … безоговорочная поддержка на всех уровнях, стоиомсть внедрения низкая, стоимость как и стоимость анологичных программ, модульная — покупай то что нужно …

    … вот …

    п.с. я не реклАмирую — я высказываю собственное мнение … !

    Reply
  24. MYRZILKA123

    Агент Плюс будет намного лучше!

    Reply
  25. jobkostya1c8

    Краткость — сестра таланта 🙂 Тоже в свое время разрабатывал документацию по внедрению в БП 2.0 КОРП инструкцию по работе с основными средствами для пользователей, не только для бухгалтеров. Подобную справочную информацию (особенно выдержки из списков регистров) во введении стоило в свое время поместить (или уже в приложение к руководству). А так создал почти как в стандартном описании:

    2.Объекты конфигурация компоненты «Бухгалтерский учёт» по учёту ОС.

    3.Примеры учёта в 1С.

    взяв только сквозной пример собственной доработанной на месте конфигурации.

    Reply

Leave a Comment

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