<?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
+1 Однозначно
Че-то штрыканул — коммет раньше времени записался.
Будем ждать Off-line версию раздела «Программы 1С». Хорошо бы токо описания и комметы, а саму прогу — ссылка.
+1, полностью поддерживаем Василия, «Программы 1С» в формате CHM — это было замечательно!
(VasilyKushnir, support)
Будет, но не сегодня 🙂
+1
> Будет, но не сегодня 🙂
Очень будем ждать! ))
Судя по счётчику, первая часть архива разработок пользуется большей популярностью :))
а я бы и +5 сделал или больше. Всё-таки лучше, чем Teleport’ом всё качать.
>Судя по счётчику, первая часть архива разработок пользуется большей популярностью :))
Вторую уже несколько раз качал — пустая… Илми это продолжение в едином архиве 1-й части?
(VasilyKushnir) Всего три файла для скачивания: первый — «самостоятельный» архив, остальные два — двухтомный архив. Для успешной распаковки двухтомного архива нужно скачать оба тома 🙂
Теперь все понятно (вот чувствовал, что 0.5+0.5 будет литр, а математически доказать не могу…). Жаль, что нельзя еще раз проголосовать…
+1
Без всяких сомнений
+1 Молоток!!!
+ однозначно
Сэкономило кучу времени (и нервов) , спасибо !
конечно автору за заботу +. но, думаю, было бы неплохо включить в архивы и сами разработки — по примеру диска с ПроКлаба. Да. пусть они изменяються со временем — просто будет более новая версия архива.
Спасибо за работу! Знания самое ценное. Удачи.
Ну, очень большое спасибо…!!!
А новая версия когда будет? 🙂
Думаю, что пора — уже целый год прошел
ДА! ЖДЕМ!
ЖДЕМ!
Будет, но не сразу. Хочу подразобраться с некоторыми вещами и сделать по другой технологии. Совместить приятное с полезным, так сказать 🙂
Кстати, какая последняя версия HTML Help Workshop? Уж больно глюкавая это прога, замучила совсем…
А для программ «версию для печати» можно сделать?
Новый CHM-архив «программ», 1359 статей по состоянию на 02.12.2007г. Файл занимает ~54 Мб, сюда его закачать мне не удалось. Выкладываю на рапиде:
http://rapidshare.com/files/73654153/infostart_progs.rar.html
Судю по популярности, пора открывать торговлю дисками? 🙂
Предлагаю сделать БД в 8.1, чтобы можно было полнотектсовый поиск юзать.
Такой вариант вытеснит все остальные палюбому.
tormozit
Не вытеснит, хотя бы потому, что 8.1 не у всех есть, да и не всем нужна. Полнотекстовый поиск есть и в CHM, кстати, можно использовать «*» и «?».
АльФ
Торговля дисками — вещь неплохая, если чётко организована. Но чётко организовать её — нужно большое желание и возможности. И ещё — нужно чётко понимать, чем торгуешь. В моём понимании — информация должна быть свободной, поэтому продавая диск, ты продаёшь услугу по копированию информации, которая только увеличивает удобство использования этой информации, не более того. Поэтому цена за такие диски должна быть соответствующей (ну, как например, дистры Линукса на дисках продают).