<?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='\
Очень нужная и необходимая вещица.
чувак. Сам такую же писал. Еще и 3 клиентам продал )
(2) На инфостарте ничего подобного нет. Я искал. Если написал — выкладывай ссылку. Я тоже когда-то продавал до кризиса. Теперь не покупают — так не пропадать же добру.
Добавьте в обработку макет «Параметры_Авторегистрации», используемый для автоматического заполнения принадлежности печатной формы в справочнике «Внешние обработки» состоящий из 2-х колонок – «полное имя метаданного» и «имя табличной части»
Нужная вещь
(4) Добавлено!
А у меня ничего не получается. Выходит обычная ИНВ-1 с указанием ОС и по МОЛ не выбирает, а где ж материалы? У нас 8.1.13 БП
1) Проверьте настройки своих субконто.
В описании этой обработки есть уточнение: «Отбирает по МОЛ при использовании на счетах субконто «РаботникиОрганизации». »
2) Если не попали материалы — значит у вас нет их в остатках по выбранным счетам.
Да все получилось, подхватывает сч. МЦ.04 по МОЛ, но сама ведомость выходит ИВН-1 (ОС), а надо-то по материалам ИНВ-3
Эта обработка делает именно ИНВ-1. Для ИНВ-3 есть другие разработки.
(9) Изначально бухгалтеру требовалось ИНВ-1. Вы уверены, что по данным счетам вам надо именно ИНВ-3?
Да, мне необходимо составить ИНВ-3 по забалансовым материалам, т.к. раньше мы в др. программе делали такую (привычка)
ок. возможно добавлю
Будем надеяться и ждать.
Ставлю минус, к моей базе не подходит, и в модуль не залезть, да не исправить.
(15) Большая просьба указывать релиз конфигурации, если у вас что-то не заработало.
(13) Плиз, ускорить движение по добавлению, тяжко ждать.
(17) Сейчас совсем нет времени, т.к. мои немногочисленные клиенты сдают квартал. Да еще учебой занялся …
Наверно после 20 апреля опять буду без работы сидеть и воплощу в жизнь ваше предложение.
(18) Хорошо, опять буду ждать
Только начал работать с этой конфигурацией хотелось бы знать пароль от обработки
у меня как раз такое задание от главбуха, а возиться с паролем некогда, помогите!!!
по счету МЦ.04 нет МОЛа, только подразделение, а отбора не предусмотрено.
Если не собираешься продавать обработку, то зачем закрывать модуль.
Теперь платно
Очень пригодилась обработка, сейчас работает в составе конфигурации.
Не совсем практична для МЦ счетов.
Зачем создавать документ для счетов, которые он не поддерживает.
Проще было использовать её для счетов МЦ именно как отчёт, не создавая документа.
У меня 1 С 8.2 КОРП пишет : «Ошибка загрузки документа. Внешняя обработка не может прочитано текущей версией программы
(26) Перед тем как пользоваться обработкой в 1с 8.2 надо 1 раз открыть обработку в конфигураторе, она сконвертируется для 8.2.
Спасибочки за помощь
А у меня почему то ведомость по МЦ04 остается пустой ( в чем может быть проблема?
(29) сообщите плиз номер релиза вашей конфигурации
Бухгалтерия предприятия, редакция 2.0 (2.0.25.5) (http://v8.1c.ru/buhv8/)
http://www.1c.ru)
Copyright (С) ООО «1C», 2009 — 2011. Все права защищены
(
(31) проверил на этой конфигурации отлично работает.
Возможно вы не добавили субконто «РаботникиОрганизаций», как об этом просит программа.
Прочитайте служебное сообщение, Которое у вас выскакивает на экран.
спасибо пригодилась, народ доволен))
А как же 10.МЦ он только в налоговом. Не подходит
(34)Пишите подробней
Вообще никто не запрещает и подправить если что самому….
(36)Это призыв к взлому обработки?
(37) нет, если честно имел ввиду то что если кому не нравится можно и свое написать и не более.
Очень полезный отчет, автору респект!
Увы. Деньги на ветер. Оказалось — это демо. Всего 10 позиций.
(40) Обновлено. Тут Полная версия (без ограничений), не демо. Если у вас возникли какие-либо проблемы с обработкой — обращайтесь лично.
Добрый день. можете выложить здесь файл Вашей обработки, связи с моей нехваткой стартмани, буду очень Вам признателен.
Скачал. пробую пользоваться.Скажите пожалуйста, а печатная форма ИНВ-3 поддерживается ? если да, то как её вызвать ? С ИНВ-1 все получилось, работает…
А так понял ИНВ-3 не используется…планируется ли доработка этой замечательной обработки ?…
(44) b-dm, этой обработкой вы заполнили документ «Инвентаризация товаров на складе», а уже из документа можете печатать стандартную ИНВ-3
(45) понятно, это тоже неплохо в принципе…а напечатать прямо из этой обработки доработать можно или проблемно ?) было бы идеально прямо из обработки печатать..
И ещё вопрос, также необходимо заполнение по счету 10.11 это возможно доработать ? В таком же ключе как по счету МЦ04 или МЦ02
Соглашусь с b-dm, у меня тоже просят заполнение по счету 10.11, так же как сделано по счету МЦ04 или МЦ02, тогда для меня это было бы интересно.
а реквизит счет учета в обработке нужно ручками подставлять ? сам он почему то из вашей обработки не заполняется…
(49) b-dm, (48) gigagr, Готово. Пробуйте.
(50) появился в списке счетов, правда не проеврял как заполняет…возник очень важный вопрос, а по подразделениям отбор сделать можно ? например у нас много подразделений и каждый бухгалтер хочет заполнять и видеть только своё ? а вот вводить новое субконто в план счетов представляется более проблематичным. это например касается вопрос счета 001.
А чтобы выбранный счет автоматически подтягивался в документ сделать можно ? В графу счет учета ?
(52) b-dm, я уже писал, что это уже сделано)
(51) b-dm, я не понял, откуда брать подразделение?
(53) да, счет поставляется…а можно ли сделать дополнительный отбор по подразделению ?
(54) например из справочника складов 🙂 в ином случае как я понимаю надо добавлять реквизит подразделение в документы инвентаризаций…Просто думаю, как быть если складов несколько принадлежащих одному подразделению..
(56) b-dm, можно добавить субсчета. Каждый субсчет будет подразделением.
(57) то есть все равно править план счетов ? и кроме этого править документы, так ?
(58) b-dm, нет. документы не придется править.
Обновление для Бухгалтерии КОРП добавлен отбор по подразделениям.
(60) Чудесная обработка и правда работает! 🙂 а можно сделать так, чтобы колонка «учет количество» заполнялась равная количеству ?или опционально, чтобы можно было как заполнить так и оставить пустой ?)
В Комплексной автоматизации работает по 002 счету. Надо сделать сортировку -исправить 10 минут приходится писать автору и ждать, т. к. код закрыт. И алгоритм не понял — зачем привязка к документа, если отчет показывает всю номенклатуру только дату берет из пустого непроведенного документа Инвентаризация ОС.
(62) buval,
1) сортировку чего надо? по номенклатуре?
2) к документу привязано для того, чтобы использовать как внешнюю печатную форму.
в 8.1 не открылось. еще и код за паролем.
(64) сообщите пожалуйста текст ошибки
(64) подскажите, для чего вы используете платформу 8.1 и не обновляете ее?
ДОбрый день! А для счета МЦ-01 возможна доработка? Платформа 8,3, Бухгалтерия предприятия КОРП, редакция 3.0 (3.0.63.15)
(67) добрый день. Да, конечно. Напишите в личку, что вы хотите доработать.
(68) не уходят вам сообщения
(69) я вам написал только что. проверьте пожалуйста.