<?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='\
Не вдаваясь в подробности, заявляю: это есть хорошо.
Ставлю авансом
походу, рано плюсанул. уже минут 20 ищет дубли, номенклатуры всего около 20 тыс
(0) Хорошо. Остается приделать любой вид справочника и возможность выбора элемента в документ прямо из обработки
+ так и убил процесс, не дождавшись…
платформа 8.1, УТ 10.2, доработанная
(0) Косячок. В обработке Таб.НоваяКолонка(«Эл»,»Справочник.Контрагенты»); Соответственно, элемент не открывается. Переделал на Таб.НоваяКолонка(«Эл»,»Справочник»);
В этих делах самое удачное (а главное быстрое) решение — это ВК StrMatch.dll
http://infostart.ru/projects/1915/ У чебура по-моему что-то было на эту тему.
Сам её использовал здесь:
Отмазка «у меня без ВК» — не катит ;)))
(3) 20 тыс можно победить, знаю как
(7) Реально, косячок ) Сейчас исправлю.
(8) Согласен. Но у меня без ВК 🙂 Собственно, и ставил целью сделать без ВК
(4) Любой вид справочника — не сложно. Сперва так и хотел. Но потом подумал, а что нужно защищать от повторений, кроме номенклатуры и контрагентов?
(10) Да я уже переделал:) Какой справочник хочешь проверить, в том и вызываешь обработку
Ошибка в Бухгалтерия предприятия, редакция 1.6 (1.6.15.6)
{Форма.Форма(62)}: Ошибка при вызове метода контекста (Закрыть): Операция не доступна для не открытой формы
ЭтаФорма.Закрыть();
по причине:
Операция не доступна для не открытой формы
(12) Исправил.
(13) обработка поработала-поработала и закрылась…. Это правильно?
(14) значит, не нашла ничего. а правильно или нет — не знаю. как правильно?
(15) вот на десятом счете несколько похожих ТМЦ болтаются, и никто не обнаружен:
Папка скоросш-ль, А4, прзрачный верхний лист синий
Папка скоросш-ль, А4, прзрачный верхний лист черны
Папка скоросш-ль, А4, прзрачный верхний лист серый
Папка скоросш-ль, А4, прзрачный верхний лист красн
Ручка шариковая «PILOT» красная
Ручка шариковая «PILOT» синяя
Ручка шариковая «PILOT» черная
Ручка шариковая «PILOT» зеленая
—————
РЕЗЮМЕ: наверное я не в ту сторону обработку запустил 😉
(16) Проверил. Все — ок. наверное, не в ту. Читай
… комментарии к установке.
Что я делаю:
1. Добавил в справочник «Папка скоросш-ль, А4, прзрачный верхний лист синий»
2. Добавляю «Папка скоросш-ль, А4, прзрачный верхний лист серый»
Открывается проверка. Проверяю. Находит.
(18) > … комментарии к установке.
А почему нельзя сделать просто как «внешнюю обработку» или «внешнюю печатную форму» к справочнику ? …Подключил — и — проверяй!
—-
Увы, я бухгалтер, а не программер :-/
(19) Это будет уже другая задача. Можно и такую. А бухгалтерам написал: «автор готов оказать помощь в интеграции этих проверок в вашу конфигурацию» 😉
(20) Очень надо… А то даже качать не стала, потому что не знаю как ее применить… А дубликатов в базе много не то слово…
У меня 7.7…
(21) Олюнчик, у меня сейчас проходит обкатку на номенклатуре порядка в 30 тыс наименований побработка поиска дублей… скоро будет выложена…
(24) Не тронь Олюнчика, развратник! Девушка хочет ездить на мерсе (т.е. работать с моей обработкой) а не на запорожце 🙂
(21) Кстати, Olyunchik, отписался в личку еще вчера.
(25) Ваш мерс (на самом деле китайской сборки) — жрет кучу бензина и наработка на отказ у него маленькая, а мой — ездиет реально везде! 😉
(27) Ы… Вот и будет повод померяться пиписками )) Только в своем мерсе ударю кувалдой кое-где. Я ведь выложил версию для широкого использования, но ее можно сделать более быстрой при несложной доработке.
Порадовала терминология в коде относительно символов «мусора» 🙂
еще не пробовал но как попробую свое мнение напишу 😉
По просьбе гутентага сделал групповую обработку справочника номенклатуры. Алгоритм сравнения оптимизировал для групповой обработки:http://infostart.ru/projects/4964/
Да у нас и 100 тыс. летает
(32) не принципиально… для 100 тыс будет у меня просто увеличение предстатрового интервала времени (если все штатными методами)
(34) Плюсану за тебя.
+ (34) И тебе 🙂
(34) Раньше надо было думать. Когда ботов заводили.
Очень медленно работает поиск:(
(38) Медленно в текущей реализации. При небольшом изменении в конфигурации метод можно ускорить в десятки раз. Если интересно — пишите в личку.
Хм…. А какова производительность на 500+ тыс элементах?
Такая обработка есть в сервисе типовых конфигураций!!!
(41) Такой нету. В 77 нет никакой.
Да уж. Ну очень медленно работает. Без оптимизации не обойтись. Скорее всего нужно хранить нормализованное наименование в справочнике и выборку, возможно, делать запросом.
Еще нужно добавить обработку прерывания пользователя. А то если уже что-то нашел и пользователь хочет отменить дальнейший поиск, нужно только снимать задачу.
(43) Нет, не в справочнике. Версия, которую ставил клиентам по запросу, формирует список значений при открытии конфы, и в нем хранит. Это дает прирост скорости в десятки раз.
(45) И, если справочник 100 тыс. наименований…
(46) Да. Но здесь, конечно, скорости не достаточно. проверку нужно делать не средствами языка, а ВК.
(45) А если какой-то элемент номенклатуры был переименован? Нужно отслеживать и обновлять список значений. Почему не сделать это хранимым реквизитом справочника. Это и ускорит запуск 1С, и поиск элементов.
(48) Потому что работа с объектом в базе данных — медленнее, чем работа с объектом в памяти.
хорошая штучка, полезная
Обработка хорошая, добавил в конфигурацию. Все запускается, ищет!
Но, если у меня есть элемент справочника «Стол письменный круглый», а я хочу добавить просто «Стол письменный» или «Стол письменный квадратный». То обработка ничего не находит и просто записывает элемент.
Судя по дате обновления, ошибки и недочеты в производительности были устранены или я ошибаюсь?