<?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) позицию можно не поддерживать, а в жизни так бывает сплошь и рядом. И этот отчет поидее инструмент для облегчения жизни экономисту.
ОБРАБОТКА НЕ ЗАПУСКАЕТСЯ. КАК ЗАПУСТИТЬ
ОБРАБОТКА НЕ ЗАПУСКАЕТСЯ. КАК ЗАПУСТИТЬ ?
Что-то с ней не так, не хотит работать и запоролена
не работает. каких-то библиотек ей не хватает
(3,4) Сорри, забыл указать, что файл precomp.dll нужно положить в папку с базой
Перезалил архив, теперь чтобы установить отчет, его нужно просто распаковать в папку базы данных.
Для тех кто на бронепоезде, повторяю: Не в ExtForms, не ещё куда-нибудь, а именно в папку БД.
(1) любое мнение мне всегда важно, тем более от Че 🙂
это всяко лучше чем, просто молча скачать. Так вот, могу ответить
по этому поводу следующее:
Я не знаю, как у вас, но у нас политика примерно такая:
Бухи, в первую очередь отвечают за правильное ведение учета, именно бухгалтерского учета, и своевременную сдачу отчетности налоргам и прочим государевым людям, чтоб как можно меньше было у последних поводов и причин впаять нам штраф или какую-другую печаль.
А вот подавать циферки руководству под «разными соусами» — это уже забота экономистов, финансистов и иже с ними…
есть под восьмерку —реестр поступленийрасхода по ДДС
(10) Это, типа, прорекламировал чтоль? 🙂
Расппаковала в папку базы данных а дальше … Можно для неумех поточнее?
(12) А дальше — запускаем 1С Бухгалиерию и смотрим в Сервис->Дополнительные возможности. Должна появится строка — «Отчет по движению денежных средств». Открываем — пользуемся. В отчет встроен небольшой хелп — посмотрите.
(11)нет 😀
Слабенький компьютер долго думает, а так все класс!
(15) Ну тут ничем помочь не могу 😳
😀 И вправду долго формирует, но отлично, я лично +
(17) Спасибо 😳 Вот все бы так…
А то 150 скачавших, а комментов кот наплакал, про оценки я уж вообще молчу… Или всех настолько всё устраивает..?
Понравилось. Спасибо!!. Однозначно, +(плюс)
(19) И вам спасибо 🙂
Здравствуйте! Никак не могу начать пользоваться вашим отчетом! скачала, открываю и вот какую информацию мне выдает:
«компонента прикомпиляции недоступна!»
а потом снизу в окошке:
«ИнфСтрока
Функция не обнаружена»
я распаковала архив и открыла его по простому- файл-открыть
Я что-то делаю не так? 😮
Очень нужен ваш отчет и хочетсся вам за него плюсик постаивть 😉 ! Помоги пожалуйста!
Не могу воспользваться отчетом, пишет: компонента прикомпиляции недоступна 😮
что это?
(21,22) В описании читали «Для установки отчета — необходимо просто распаковать архив в папку с базой данных«? При этом всё будет работать нормально, а сам отчет попадет в папку ExtForms и будет доступен из меню «Сервис->Дополнительные возможности».
Если же вы хотите «хранить» отчет в другом месте и запускать его оттуда же, то для корректной работы необходимо файл «precomp.dll» из архива положить в каталог с информационной базой, либо в каталог программы (по умолчанию находится «C:Program Files1Cv77BIN»)
Не сработал,написал Поле агрегатного объекта не обнаружено (ДвиженияДенежныхСредств) Чем можно помочь (к сожалению в программировании 0)
(27) А Вы на какой конфигурации его запускаете?
🙁 1C 7.7 версия 3,6 .Это жена на ней работает ,просит иногда что то скачать и помочь. Не могу ведь перед ней в грязь лицом 😎
думаю пора под 1С8 данный отчет переписать
(30) c 1C8 не работаю ваапче пока…
+ посмотри (10), может устроит
Спасибо, отчет понравился, то что нужно к годовой отчетности.
Спасибо, отчет понравился, то что нужно к годовой отчетности.
> первая хочет максимальной ясности при ежемесячном АХД, вторая не хочет раздувать вышеуказанный справочник (что я тоже поддерживаю) и мучаться правильно проставлять аналитику в документах и проводках.
— т.е. типа из-за лени бухов — на тебе экономитс инструмент и бодайся..? типа так? хотя это первоочередная задача бухов — давать ясные и прозрачные цифры/отчеты по хоздеятельности предприятия.
.
так что позицию автора — не поддерживаю…
Хороший отчет.
Хорошо-бы в этот добавить еще одно субконто — Договоры
Это было бы идеально
(35) Куда добавить субконто???
Еще одну колонку Корр. субконто 2 что ли?