<?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) У меня в конфигурации такая переменная определена:
«Управление торговлей», редакция 10.3 (10.3.3.3):
Основная конфигурация Конфигурация.УправлениеТорговлей.Модуль приложения(6, 7) : Перем глТекущийПользователь Экспорт;
Основная конфигурация Конфигурация.УправлениеТорговлей.Модуль приложения(57, 2) : глТекущийПользователь = ПараметрыСеанса.ТекущийПользователь;
(2) а у вас какая конфигурация?
Лично у меня ошибка не выскакивает.
А таких проффесионалов как Maniac такая мелочь не остановит 😉 Ведь код открыт!
Постараюсь поправить.
Я сам не программист, а заказчик. Некоторые мелочи я смогу поправить.
А так я всеми руками за если кто-нибудь иправит обработку (сделает ее универсалтной для всех конфигураций) и выложит ее.
(1) Обновил. Теперь выскакивает ошибка?
УТ 10.3.7.8 ошибка по кнопке «Формирование заказа»
{ОбщийМодуль.ОбщегоНазначения(1822)}: Невозможно обработать параметр «ТекПользователь» для получения значения
ВызватьИсключение СтрокаИсключения;
Какая то прямо «маниакальная» неприязнь к чужому труду :)))
Маньяк, ты внатуре маньяк 🙂
(9) Отчет мой. Я разработал ТЗ. Я заплатил за его выполнение.
(10) Планирование будущих продаж расчитыватся исходя из продаж прошлых периодов. Т.е. он считает средние показатели продаж за прошлые периоды (можно задать несколько периодов с коэффициентом веса этих периодов для учета сезонности). Расчитывет сколько товара продастся в задаваемый период(= средняя продажа * кол-во дней (задается пользователем -это обычно количество дней до следущей закупки)). Из этого количества вычитаются существующие остатки и получается количество товара необходимое для заказа. Галочку учитыват или не учитывать резервы мне сейчас доделывают. Так что будет в следующей версии.
Общая формула расчета такая:
План продаж(расчитанный по динамике — (Остатки — Резервы)
Заказы поставщикам я умышленно не хотел учитывать. Мое личное мнение если по продукции еще остался не закрытый заказ и мы делаем еще один, то старый заказ в 99% уже не нужен. Это сугубо мое личное мнение. Можете не соглашаться 🙂
(10) Что отчет может показать по новой продукции, которая еще не продавалась?
(12) Маньяк так злится потому что его «нормально решение (недорогое) и проверенное —http://infostart.ru/projects/3743/ » меньше будут покупать.
http://www.infostart.ru/projects/3295) .
Хотя совсем недавно он злился, что нормально решение (недорогое) и проверенное другого программиста продается за деньги (
Может некорректно задавал параметры — считало как здря(
ставлю + за открытый код
возможно надо дорабатывать под себя
(16) Я буду очень рад если эта обработка подойдет хотя бы одному пользователю.
(8) Исправил. Пробуйте.
(10) Посмотрел ваш отчет. В нем тоже присутствуют ошибки и спорные моменты. И логика анализа и прогнозирования ничем не отличается. Так что очень странно слышать что ваш отчет «нормальный» и «проверенный» в отличии от этого.
Плюс вашего отчета (хотя в демо версии этого нет) это форма редактирования данных перед тем как сформировать заказ.
Когда нажимаешь на кнопочку «Формирование заказа» выходит ошибка {ВнешняяОбработка.Заказы(895)}: Метод объекта не обнаружен (УстановитьДатуОплатыПоДоговору)
НовыйЗАказ.УстановитьДатуОплатыПоДоговору();
Конфигурация УТ 10.3.7.9
И не хватает доп колонок, например артикул номенклатура и полное наимевание
а в целом «+»
Работает в УТ для Украины. Пока в целом тоже плюсану.
Ошибка как и у (24)
Работаю в «Управление торговлей», редакция 10.3 (10.3.5.1)
а так так же «+»
(20) может забыли коэф. для периода поставить?
Теперь считает резервы правильно
Какой замечательный отчет! Функциональный и удобный!
Привет, поставил в отборе номенклатуры группу товаров из 3-х артикулов. Период 1 равен месяцу… обработка ушла считать и не вернулась, по одной позиции делает достаточно оперативно. Не знаю пока в чем конкретно дело — буду смотреть. Пробую на доработанной УТ, но структура основных справочников и регистров не изменялась.
Если есть какие-то идеи или быть может уже исправлено, подскажи пожалуйста.
Очень пригодился. Спасибо, что код открыт и можно подправить под свои потребности.
Отчет хороший, но при расчете дней продаж не учтено что в какие то дни товар отсутствовал на складе.
УТ 10.3.12.3
При попытке открыть обработку, ошибка:
{Форма.ГлавнаяФорма(116,25)}: Переменная не определена (глТекущийПользователь)
Если ЗначениеЗаполнено(<<?>>глТекущийПользователь) Тогда
{Форма.ГлавнаяФорма(116,25)}: Переменная не определена (глТекущийПользователь)
Если ЗначениеЗаполнено(<<?>>глТекущийПользователь)
Можете подправить?
Ну, в принципе, обработка годная. Плюс — в наличие учета сезонности. ОГРОМНЫЙ минус — отсутствие учета товара по размещенным заказам. Абсолютно не согласен с тем, что вы писали на счет отсутствия учета заказов. Постоянно приходится сверяться с тем, что ты заказал, оплатил и товар уже в пути. Поэтому, очень хотелось бы видеть колонку «Заказано» в вашей обработке.
Удачи.
(32) IDija, отчет как раз расчитывает сколько дней товар был в наличии.
(35) Разобрался и переделывал под себе много раз. Еще раз спасибо, очень помогла обработка!
Плюс однозначно, жаль что пока не могу скачать.
Спасибо огромное за обработку, очень пригодилась 🙂 Последнее время всегда нахожу что-то полезное на инфостарте, спасибо создателям его 🙂 И Вам еще раз огромное спасибо.
По поводу Заказов: Правильно кто-то заметил, что иногда Заказы нужны, особенно если крупные поставки и из разных мест, но так как код открыт, доработать его можно, было бы желание или немного ден. средств :)))
Типовые механизмы планирования напрягли деталями, здесь все просто!!!
{Форма.ГлавнаяФорма(116,25)}: Переменная не определена (глТекущийПользователь)
Если ЗначениеЗаполнено(<<?>>глТекущийПользователь) Тогда
{Форма.ГлавнаяФорма(117,69)}: Переменная не определена (глТекущийПользователь)
ДатаНачала = УправлениеПользователями.ПолучитьЗначениеПоУмолчанию(<<?>>глТекущийПользователь, «ОсновнаяДатаНачалаОтчетов»);
Наверняка просто нет такой переменной, а точнее она есть, только в в Вашей редакции УТ называется по другому. Откройте конфигуратор и посмотрите, что да как, сделайте поиск по слову Пользователь, посмотрите как в конфигураторе эта переменная называется и в данном отчете исправьте так же через конфигуратор.
Кто нибудь может добавить в данную обработку учет товара по размещенным заказам? Готов поддержать фининсово.
{Форма.ГлавнаяФорма.Форма(116,25)}: Переменная не определена (глТекущийПользователь)
Если ЗначениеЗаполнено(<<?>>глТекущийПользователь) Тогда
{Форма.ГлавнаяФорма.Форма(117,69)}: Переменная не определена (глТекущийПользователь)
ДатаНачала = УправлениеПользователями.ПолучитьЗначениеПоУмолчанию(<<?>>глТекущийПользователь, «ОсновнаяДатаНачалаОтчетов»);
УТ 10.3.16
Хорошая разработка. Как раз сел писать такую с нуля, часть написал — решил посмотреть еще идеи. Только здесь сходу в коде не разберешься. Чтобы внести небольшое изменение требуется много работы и придется переписывать часть функций.
Написали?
Для УТ 2.3 для Украины ,обычные формы пойдет ?
В УТ 10 продажи за период (первая колонка) считает без учета реализаций по ордерам. Розницу и реализации со складов учитывает.
нет панели отбора… на скрине есть. как быть?
(46) Перейдите в Настройки. Там есть отбор.
(47) это мы нашли, но вылетают сплошь и рядом ошибки связанные с отбором. Например, что не задана ГруппаСкладов, когда нажимаем кнопку Анализ продаж и нужно без отбора по складу. И в других случаях.
заходить в настройки, ставить отбор, сохранять, заходить в настройки, снимать, строить — очень не удобно, к тому же на скринах есть та панель. может есть рабочая версия с панелью отбора? можете кинуть?