<?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='\
Будет ли работать с УНФ (Управление нашей фирмой, редакция 1.6) ?
не пробовал. думаю если это конфигурация под УФ и использует БСП то да. Посмотрите на константы, есть ли там ИспользоватьАльтернативныйСерверДляЗагрузкиКлассификатораБан ков
если да то будет
Так понимаю 1С всё ещё сосет инфу от холдинга с головой на Кипре.
Спасибо, пригодилось, только пришлось переписать, т.к. в версии 3.0.52.42 уже загрузка идет с сайта 1С, а не с сайта РБК.
Так же поменяли название справочника с КлассификаторБанковРФ на КлассификаторБанков и константу так же.
Будет время выложу.
Понял! Не заглядывал туда уже давно. Как я понял, теперь классификатор обновить можно только с ИТС или сайта 1с? А через rbk.zip не возможно?
Разобрался. Выложил новую обработку для БП старше (3.0.52.36)
Требуется доработать загрузку файла с машины клиента.
(7) А что надо переделать? Там тонкий клиент? под тонким все работает.
Сервер не будет видеть путь к файлу который лежит на машине клиента. Только если вы запускаете тонкий клиент на сервере.
(8) Например так:
Показать
ок! я сегодня постараюсь переделать. Выложу. кидайте свой мэйл вышлю
Переделал! давай мыло, кину на проверку. А то у меня апач лег, а др тонкого нет
У меня так и не получается загрузить классификатор((( 1с 8.2. Нажимаю загрузить с сайта РБК и ничего не происходит(((
А так хочется загрузить,надоело вбивать в ручную.
Доброго дня!
На ЗУП 3.1.4 не работает………
А где заявлено что на зуп она должна работать?
Переделал! Оказывается 1с начиная с версии Бухгалтерии предприятия 3.0.52.42 1С искоренили механизм загрузки с РБК. Я перенес все функции загрузки с РБК в обработку.
Проверено на Бухгалтерия предприятия, редакция 3.0 (3.0.52.39) и Зарплата и управление персоналом, редакция 3.1 (3.1.4.167)
Сделал все как по инструкции, ничего не появилось. Захожу вбиваю БИК и ничего не находит. зуп 3.1.4.169
А загрузилось хоть что то?
(18) нет
Специально развернул чистую ЗУП31 и загрузил — все работает!
(20)Скачал обработку, скачал архив, запустил, выбрал путь к зипу, написал «Загрузил». Захожу и в справочнике пусто. Релиз 169. Платформа 8.3.10.2580….. Хз что не так
а zip файл откуда брал?
(22) по твоей ссылке в статье
тогда не понимаю почему — у меня все работает см картинки
хм еще что подумал а в «справочник заходил» а пробовал его переоткрыть или F5 нажать что бы данные на форме обновились?
Письмо с обработкой не пришло 🙁 ………….. на почту nkolp@inbox.ru
Оппс, мани пропали или не тот аккаунт …
Я не знаю в чём дело Пишите в администрацию сайта.
(26) выслал на почту на всякий случай
Добрый день, в версии 1С:Комплексная автоматизация 2 (2.4.3.126) загружает с сайта bnk.zip а в прогу не прописывает и не обновляет справочник
Добрый! В описании написано:»Проверено на Бухгалтерия предприятия, редакция 3.0 (3.0.52.39) и Зарплата и управление персоналом, редакция 3.1 (3.1.4.167)» Если хотите я за доп вознаграждение проверю как работает на указанной версии и если что поправлю. Пишите в личку helmer@ya.ru
1. Создаем папки на любом диске (у меня D:)
D:1CITSEXEEXTDB
D:DatabaseGarantMorphDB
2. Заходим на сайт rbc и Скачиваем файл bnk.zip (в браузере —http://cbrates.rbc.ru/bnk/bnk.zip)
Переносим bnk.zip в папку D:1CITSEXEEXTDB
3. В папке D:DatabaseGarantMorphDB создаем файл с именем Morph.dlc
4. В стандартной загрузке классификатора банков с диска ИТС выбираем Диск D: и Загрузить
Все загрузится.
Вся причина:
На диске ИТС нет файла D:DatabaseGarantMorphDBnk.zip, поэтому создаем свой диск с нужным файлом.
благодарю
(32) Пишет ошибку «На диске ИТС не обнаружен файл обработки подготовки данных классификатора БИК РФ».
Бухгалтерия 3.0.54.15
(34) это вопрос к разработчику или ответ на 32 тему? по загрузке с созданного каталога?
(35) Это был ответ на 32 реплику. Разработчику я был не прочь заплатить за эту обработку, но оказалось, что необходимо покупать абонемент впятеро превосходящий её по стоимости… (
На одной из картинок есть мой е м а й л пишите! договоримся
При наличии Интернета и неоформленной подписке на ИТС обновить справочник банков можно — в пользовательском режиме установить флажок в Константе «Использовать альтернативный сервер для загрузки классификатора банков».
Работает в БП 3.0, ЗУП 3.X и УТ 11.X
И что из этого вы можете выбрать, что бы загрузить? Константу я включил. 1с уж как год назад заблокировало все альтернативные подходы.
(39) может и нелогично, но выбрать «С сайта 1С»
попробуйте! без логина и пароля не выйдет
(41) сами пробовали? У меня нормально выходит. БП3
(41)Да, нужно выбрать «С сайта 1С». Без логина и пароля.
Работает 100% на конфигурациях БП 3.0, УТ11,х, ЗУП 3.х. Загружал, и не один раз. 🙂
что то не выходит. Отключите у себя инет поддержку и попробуйте!
(44) константа точно установлена в true?
Вы правы! в пред конф установил, а в этой взятой для теста — забыл. Да! Работает, если выбрать «С сайта 1с»!
(38)Спасибо — получилось загрузить банки именно с сайта 1С после установки этой константы!
Кому надо, держите. Мое. УТ 11 проверено
На бухгалтерии 2.0 обработка работает?
нет. только под УФ