<?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='\
Открываешь организацию, там есть поле регистрации в ИФНС. В нем меняешь коды и перевыбираешь регистрацию.
Надо пользоваться типовым функционалом.
Хорошо бы было добавить кнопку открытия сайта соответствия кодов ОКАТО И ОКТМО Да и еще мне пришлось править регистр накопления НДФЛСведенияОДоходах — в реквизиты добавлять ЗарегистрированоДляПромежуточногоРасчета и ДатаПолученияДохода (бух.2.0)
http://infostart.ru/public/249238/
Кстати вот таже тема
(1) tiniji, В первую очередь обработки нужны для внесения изменений в уже обработанные данные учета, а не для изменения кода ОКТМО в карточке организации, что легко делается руками.
(3) так и надо писать, что «ввели больше нулей чем нужно и успели наделать проводок». А не просто «нужно исправить ОКТМО, т.к. ввели больше нулей чем нужно». Тогда и претензий меньше возникнет.
А уверены что ввели лишние цифры? Восемь цифр в ОКТМО вроде только у Москвы с Питером, все остальные регионы — 11.
Т.е. город Астрахань — 12701000001.
(5) Drak0n,
Для Москвы и Питера ТОЛЬКО 8 цифр.
Для всех остальных либо 8, либо 11.
вроде на зупе работает
Спасибо. Очень актуально для ЗУП из-за «бестолковщины» в ОКТМО то 11 то 8 цифр, то такое ОКТМО то другое….
Только после исправления ОКТМО документы Перечисления НДФЛ в бюджет не перепроводите!
Старые коды обратно встанут в регистре иначе.
(6) Lo1jke, откуда информация? В Кировской области ИФНС и ПФР требуют 8-ми значный ОКТМО. И это не только для областного центра, но для любого населённого пункта, у которого есть 8-значный ОКТМО.
При заполнении показателя «Код по ОКТМО», под который отводится
одиннадцать знакомест, свободные знакоместа справа от значения кода в
случае, если код ОКТМО имеет восемь знаков, не подлежат заполнению
дополнительными символами (заполняются прочерками). Например, для
восьмизначного кода ОКТМО 12445698 в поле «Код по ОКТМО» указывается
одиннадцатизначное значение «12445698—«.» 11 или 8 знаков зависит от того с каким бюджетом имеете дело городской 11 федеральный 8
Обработка прямо в тему на 100%! Работаем в КА. В релизе 42. когда появилась штатная обработка, замену ОКТМО не сделали (там есть кнопочка «Отложить»). Перешли на релиз 43, запустили штатную обработку замены, в результате замена произошла только в декабрьских записях РН. Налоговый регистр по НДФЛ заполняется правильно в части уплаченного НДФЛ, а карточка для ФНС 2-НДФЛ хватает только записи по ОКТМО, остальные игнорирует. Штатная обработка повторно не запускается. Только Ваша обработка спасла ситуацию. Огромное спасибо.
6 попыток скачивания (для ЗУП), файл не открывается, т.к. 1С падает из-за ошибки потока.
Пробовал скачать разными браузерами на разных компьютерах.
(13) Аналогично!
Может это диверсионная обработка какая?
(14) gucci76, см. (16) и (17)
(13) BoneD, Обновите платформу.
(16) на 8.3.4 рабочую базу ЗУП клиент сервак переводить из-за 1 обработки… не вариант.
Открыл в ЗУП 3.0 сравнил, что там изменёно. Лучше перенесу модуль в типовую обработку.
Хоть бы написали, что платформа 8.3.
Во вложении версия для Платформы 8.2.
Не работает Ошибка потока
Респект!!!
Автору плюс!
Если кому-то нужно, то вот такая же обработка для ЗБУ:http://infostart.ru/public/252121/
а что мешает в справочнике Регистрация в ИФНС этот код поменять. Чудно и странно?!
(23) 1cspbru, обработка не в справочнике меняет, а во всех движениях за год
не обижайтесь конечно, но тут программист лоханулся по сравнению с консультантом))
это ж надо было обработку написать)))
такими темпами скоро будете обработки писать, чтобы помеченные на удаление объекты удалять, типа стандартная операция далеко)))))
(25) ты не поверишь….
http://infostart.ru/public/?q=%F3%E4%E0%EB%E5%ED%E8%E5+%EF%EE%EC%E5%F7%E5%ED%ED%FB%F5+%E E%E1%FA%E5%EA%F2%EE%E2
Попробуй в типовой обработке указать неверный код ОКТМО, нажать «обработать», а потом у организации указать правильный ОКТМО. После этого заплатить оставшийся налог или сформировать справку 2НДФЛ.
Для моей конторы я тоже стандартную обработку переписал. Вот только мне потребовалось ещё изменить ограничения по году. Т.е. стандартная берёт и проходится по данным регистров за 2013 год, а у клиента уже были набиты документы в 2014 году с не правильным ОКТМО.
Спасибо, обработка пригодилась!
Единственное, поправил в ТЧ у поля ОКТМО длину «Переменная» на «Фиксированная». Мне нужен был 7 значный ОКАТО, и документы при проведении пишут в регистр «Расчеты налоговых агентов по НДФЛ» значение ОКАТО/КПП в виде «00000000 /КПП», а обработка писала «00000000/КПП». Из-за этого потом не заполнялся документ «Перечисление НДФЛ в бюджет»
подскажите пожалуйста, а чем данная обработка может заменить типовую, что устанавливается вместе с обновлением конфигурации ?
(29) siyayushhijasinxral@mail.ru,
Типовая отрабатывает только один раз. Возможности для исправления ошибок непредоставляет
Спасибо! Хорошая обработка.
Очень полезная обработка. Спасибо автору!
Уже говорили, что надо просто зайти в справочник Регистрации в ИФНС и исправить там ОКТМО. Всё прекрасно исправляется.
Спасибо автору за труд
У меня в ЗУП всё исправилось стандартным способом, как описали выше
ну надо же писать что для платформы 8.3
или сделать для 8.2, а кому надо сконвертирует, не?