Классификация программистов 1С (8.0, 8.1 и 8.2)




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

56 Comments

  1. withoutface

    Автор, а ты в какой категории сейчас?

    Reply
  2. ILM

    Переходный период с 7) на 8)

    Reply
  3. lihomanov

    Все круто, видел таких деятелей, напишут две три стоки и все программисты 1С или установят 1С, настроят пользователя! 😀

    Reply
  4. Ish_2

    (2) Понятно. Вот почему до 7-8 п. всё более или менее убедительно,

    а 9-12 слабенько совсем.

    Reply
  5. Gilev.Vyacheslav

    LoL 😀

    Reply
  6. ILM

    (4) Так ещё дорасту, напишу поподробнее 😀

    Reply
  7. Незнайка

    если это юмор, тогда можно и плюс.

    а если нет, то минус.

    Reply
  8. zse

    Все так. Но не отражен этап превращения win сисадмина в спеца по 1С (умею ставить 1С и обновлять типовую 1С). Уровень -1. Для многих основной.

    Reply
  9. Душелов

    Ни под какой не попадаю 🙁

    Reply
  10. ILM

    (9) Предложи добавлю. Вон RayCon тоже недоволен, наверно его типовые не устраивают 😉

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

    Не обнаружил ничего достойного внимания, кроме ссылки на статью aleks-is 😐

    Это что, просто попытка автобиографии?

    Reply
  12. Ish_2

    (11) После отпуска Арчибальд очень строг.

    Reply
  13. dushich

    😀 я остановился на шестом пункте. (включительно) Пора двигаться дальше. Есть к чему стремиться.

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

    (12) Был бы строг — минус бы поставил. А так списал все на проблемы с генофондом чистопородных восьмерочников 😀

    Reply
  15. Ish_2

    (14) Ага ! Зацепил, значит, заголовок : «Семерочники не участвуют».

    Это радует.

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

    (15) Не зацепил, а прояснил ситуацию. Семерочнику как ни примерь пункты из топика — не подойдут. Чисто восьмерочный генезис.

    Reply
  17. IgorXml

    Спс, 😀

    Reply
  18. logarifm

    9 уровень всех я думаю отшил, здаю на какого хочешь спеца, здесь не так просто-то в 1С дистанционно здать на всех спецов 😎

    Reply
  19. logarifm

    А так — улыбнуло….

    Reply
  20. ILM

    Восьмерочный генезис! Хорошее выражение, надо запомнить. Тогда платформа 8.2 — это наверное катарсис 1С. 😀

    Reply
  21. Sergey.Noskov

    Улыбнуло.

    >Поучаствовал в создании шести отраслевых решений.

    можно планочку в шесть решений снизить?, а то на 7-м застряну… 😀 😀

    >Сдаю на всех спецов, какие есть.

    Останавливаться на достигнутом не хочу, но пункт 9 явно не самоцель и, надеюсь, мне не придется лечиться у доктора со всеми возможными сертификатами (проктолог, стоматолог, кардиолог в одном лице).

    З.Ы. про SQL мало, ИМХО программер в плане развития должен двигаться именно в сторону более глубого изучения возможностей СУБД

    Reply
  22. gaglo

    …генезис, катарсис… Анус мирабилис! Дополнительные определения — перфектус или комплетус.

    Reply
  23. Ish_2

    (21)

    про SQL мало, ИМХО программер в плане развития должен двигаться именно в сторону более глубого изучения возможностей СУБД

    Комиксы интереснее , чем простой текст.

    Рабочие столы, прогресс-бары , индикаторы , ВК и прочие картинки веселее и популярнее , чем SQL.

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

    (20)Семерочный вариант генезиса.

    0) УПС, на такую простую задачу такая туча текста в глобальнике. Неужели читать придется?

    1) Гм, неожиданно приличное описание языка. Объектно-ориентированный… инкапсуляция в наличии… ссылочная целостность… Но читать неохота, разберемся по ходу.

    2) Я гений, исправил в конфе пару ошибок, а через два релиза и разработчики так же сделали, как я.

    3) Совсем бухии не знаю, наймем франча и посмотрим, что он наделает.

    4) Куплю-ка я самоучитель по бухучету. И на ИТС подпишусь.

    5) Нужно убрать все доделки франча. Он хоть и аудитор, но балбес, год коту под хвост – это скажем директору. А главбуху скажем, что на новый план счетов по-другому не перейдешь.

    6) Пишем методику неразрушающего конфигурирования.

    7) Мои доработки и обновлениям не мешают, и все хотелки закрывают.

    8) На каждую предметную область – своя конфигурация!

    Reply
  25. ILM

    (22)

    Генезис — Бытиё.

    Катарсис — Очищение.

    А Анус Мирабилис — Это что-то вроде удивительная задница? Прошу прощенья )))

    Reply
  26. Winston Kent

    Дорос ровно до 5 уровня (кстати, его можно процитировать как мою просьбу? Заранее благодарен!), 6 и 7 думаю пропущу, а вот 8 интересно…

    З.Ы. Занимаюсь 1С год, 7-ка и 8-ка… Это долгое развитие?

    Reply
  27. Sergey.Noskov

    (26)

    не советую пропусакть это:

    >А вот запросы на стороне SQLServer можно и ускорить.

    Reply
  28. Душелов

    (23) >Рабочие столы, прогресс-бары , индикаторы , ВК и прочие картинки

    О, как, хорошо ВК под одну гребенку запихнул… Прям уровень один… 👿

    Reply
  29. Ish_2

    (28) Не со зла , Вася . Так случайно запихнулось… Под одну гребенку.

    Правильно читать :

    Рабочие столы, прогресс-бары , индикаторы и прочие картинки
    Reply
  30. Душелов

    (29) А то уж подумал, что некоторые творчества можно к перенумераторам отнести и рабочим столам… 🙂

    Reply
  31. GROOVY

    Так и не понял к какому конкретно пункту автор меня отнес, но себя нашел.

    Reply
  32. ILM

    (31) Угадал 😀

    Когда этот пункт писал примерно о Вас Учитель и думал, как сегодняшний семинар прошел?

    Reply
  33. Tarlich

    Все одинэсники делятся по степени образованности от тупого к умному на следующие категории — хотя все и прочитал до конца и есть с чем согласен но уже только за такое вступление —

    Reply
  34. GROOVY

    (32) Да вроде хорошо прошел. Спасибо.

    Reply
  35. din-din

    Мне кажется, что это классификатор к новому поколению восьмерочников, как сказал автор «Семерочники не участвуют», причем не участвуют впринципе, т.е. только те кто узнал что такое «1С» в лучшем случае с 8.0, а то ис с 8.1. К тем кто о семерке слышал только то, о чем бухгалтера шептались в курилке. Пройдите по шкале Арчибальда хотя бы пять уровней и будете смотреть на эту классификацию слегка по иному. Обратите внимание на то как работают восьмерочники знающие семерку и как те кто начал с восьмерки, у них же взгляды на информационную систему разные. Такие люди будут по два года сидеть на 6-м пункте и ждать пока дистрибьютор выпустит очередной релиз.

    ИМХО. Такой мой взгляд на эту ситуацию.

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

    Добавка к (24) специально для vip:

    9) Все конфую по фен-шую 😀

    Reply
  37. gaglo

    (20), (25) — перевод абсолютно верен; генезис и классификацию пропускаем; а платформа 8.2 никакой не катарсис, а именно анус мирабилис; полный и/или совершенный; чёрная дыра, что может поглотить всё свободное и несвободное время; ещё СКД не освоил, а тут управляеные формы подоспели, и т.п.

    Reply
  38. Stety

    Заглянуть бы во светлые очи 12-го пункта.

    А в 8-й пункт до шести отраслевых решений прям судьба не заносит? Прям никак по-другому до этого не дойти?

    Reply
  39. vip

    (36) Кгрхм…

    Восприму за комплиман.

    Я не свободный художник, мне надо внучку кормить.

    Я избрал свой путь, которым доставляет мне удовольствие и приносит средства к существованию.

    А без удовольствия — конфуй, не конфуй, все равно получишь ……..

    Reply
  40. akozhuhova

    😀 прикол… правда я не знаю к кому себя отнести..но где-то в начале 😀

    Reply
  41. ILM

    В следующий раз, надо бы написать статью: «Платформа 8.2. ка RPG».

    Например: 1) Загрузил 8.2. +1 к мане, -1 к силе, +10 к ловкости.

    2) Запустил управляемое приложение -10 к здоровью, +10 к мане, -5 к силе.

    Диаблу запустить нужно, что-то я все скиллы уже забыл 😀

    Reply
  42. Yashazz

    Если вдуматься, у семёрочников всё то же самое, только понятие поддержки отличается, да ещё момент про «всё можно настроить». В семёрках настраиваемость была сильно хуже. Ну, запросы были своеобразные, ну, конфу защищали одним паролем… А так — ни малейшей разницы, потому что разница не в софте и навыках, а в голове и восприятии себя и окружающей действительности.

    Reply
  43. Душелов

    Мде… Какие проблемы-то с 8.2? Управляемые формы — очень удобная и знатная штука. А компоновка — вообще тема, тем более, что в новом релизе они теперь в фоне выполняются.

    Но это так, лирика…

    Reply
  44. Трактор
    Семерочники не участвуют

    Я в пролёте. Жаль.

    Reply
  45. musatov1c.ru

    Не знаю. Наверно автор прав. Я только сегодня отрыл мануал. Достал его и понял. Надо читать! 🙂

    Reply
  46. AnryMc

    (0) Выпала категория 1С-ников которые программировать в конфигураторе не умеют, но имея отличное знание предметной области и функционала типовых решений могут «выжать» из программы то о чём разработчики и не мечтали.

    (например http://infostart.ru/public/60802/)

    Reply
  47. Михаська

    я между 7-8 ))))

    Reply
  48. Михаська

    а блин) я же семерочник.. эхх) пролетаю)))

    Reply
  49. Yury1001

    Прям порадовало – всё так и было.

    А я с 6-го на 5-й деградировал, надоело спорить – делаю всё как говорят, а потом переделываю когда клиент прозреет, двойная оплата компенсирует моральные принципы.

    Reply
  50. adhocprog

    точно написано.

    Начал со второго, пока на восьмом 🙂

    Работаю над десятым 🙂

    Reply
  51. Оля_

    Нахожусь на 6 уровне или стадии 🙂 уже давно требую от коллег: «Нужно вернуть всё к типовой конфе. И убрать все доделки предыдущих прогов.». Книжки из коробки уже не учу, хожу на курсы SQL, медленно, но верно перехожу на следующий уровень. А начинала с 5-го — думаю мне повезло

    P.S.

    Автор очень точно всё подметил

    Reply
  52. AlX0id

    Перехожу на восьмой срочно ))

    Reply
  53. a1ex4ndr

    народ жжот во всю 🙂

    Reply
  54. reshkra

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

    Reply
  55. Bukaska

    Спасибо! Поржала!))))

    Себя отношу где -то к 6-7 пункту, но есть к чему стремиться! Будем двигаться дальше)

    Reply
  56. MrFlanker

    Ничего не понял… я в 8-ке недавно совсем….. но я наверное сразу на 8-й уровень.

    Reply

Leave a Comment

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