Как получить список простых чисел в запросе




Принцип обмена данными из 1С с сайтом (на MySQL) и выдачи (публикации) этих данных по запросу.
PHP-Скрипт автоматической загрузки данных из файла данных в формате CSV в базу данных сайта работающего на WordPress.

В продолжение моей темы: 1С:Альфа-Авто Автосалон Автосервис: обмен с сайтом.
С помощью данного скрипта можно загружать в автоматическом режиме, по расписанию, данные сервисных книжек (ремонтов авто) из 1С:Альфа-Авто Автосалон Автосервис.
Также можно загружать данные в ручном режиме: для этого делается скрытая страница, где размещается специальная кнопка.
Комментарии размещенные внутри скрипта разъяснят логику и порядок действия.
Комментарии с "/////    echo" использовались для отладки.
Дополнительно создана таблица для журналирования результатов загрузки данных.
Скрипт включает в себя защиту от SQL инъекций (думаю безопасность соблюдена в полной мере).
В кратце:
1. Пишется скрипт, который запускает этот.
2. Создается регламентное задание в WordPress, по которому запускается скрипт из п.1. 
3. Этот скрипт осуществляет проверку на существование файла обмена в папке.
4. Если данные не новые, загрузка не производится.
5. Если данные новые, очищается таблица сервисных книжек.
6. Загружаются новые данные.

Собственно сам скрипт:

<?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='\

33 Comments

  1. Filipp_Hardcorov

    Я бы все равно не взял программиста, который таким образом оформил код.

    Reply
  2. Boneman

    А я бы сам не пошел в такую контору, которая дала-бы мне такую тестовую задачу

    Reply
  3. Filipp_Hardcorov

    upd.

    Не, неправ я оказался)

    И, возможно, я ошибаюсь, но нам необходимо проверить делится ли число на 2, 3, 5 или 7.

    Если не делится, значит оно — простое.

    Соответственно, как то так:

    На вход пусть подается ТЗ ТаблицаЧисел

    Функция КоличествоПростыхВТаблице(ТаблицаЧисел)
    
    Запрос = Новый Запрос;
    Запрос.Текст =
    «ВЫБРАТЬ
    | Числа.Число
    |ПОМЕСТИТЬ вт_Числа
    |ИЗ
    | &Числа КАК Числа
    |;
    |
    |////////////////////////////////////////////////////////////­////////////////////
    |ВЫБРАТЬ
    | вт_Числа.Число,
    | ВЫРАЗИТЬ(вт_Числа.Число / 2 КАК ЧИСЛО(15, 0)) КАК ДелениеНа2,
    | вт_Числа.Число / 2 КАК ДелениеНа2СОстатком,
    | ВЫРАЗИТЬ(вт_Числа.Число / 3 КАК ЧИСЛО(15, 0)) КАК ДелениеНа3,
    | вт_Числа.Число / 3 КАК ДелениеНа3СОстатком,
    | ВЫРАЗИТЬ(вт_Числа.Число / 5 КАК ЧИСЛО(15, 0)) КАК ДелениеНа5,
    | вт_Числа.Число / 5 КАК ДелениеНа5СОстатком,
    | ВЫРАЗИТЬ(вт_Числа.Число / 7 КАК ЧИСЛО(15, 0)) КАК ДелениеНа7,
    | вт_Числа.Число / 7 КАК ДелениеНа7СОстатком
    |ИЗ
    | вт_Числа КАК вт_Числа
    |ГДЕ
    | (ВЫРАЗИТЬ(вт_Числа.Число / 2 КАК ЧИСЛО(15, 0))) <> вт_Числа.Число / 2
    | И (ВЫРАЗИТЬ(вт_Числа.Число / 3 КАК ЧИСЛО(15, 0))) <> вт_Числа.Число / 3
    | И (ВЫРАЗИТЬ(вт_Числа.Число / 5 КАК ЧИСЛО(15, 0))) <> вт_Числа.Число / 5
    | И (ВЫРАЗИТЬ(вт_Числа.Число / 7 КАК ЧИСЛО(15, 0))) <> вт_Числа.Число / 7″;
    
    Запрос.УстановитьПараметр(«Числа», ТаблицаЧисел);
    Выборка = Запрос.Выполнить().Выбрать();
    
    Возврат Выборка.Количество();
    
    КонецФункции;
    
    

    Показать

    Reply
  4. tori131313

    (3) Ошибаетесь. Возьмите 11*11=121. Не делится нацело по данному алгоритму, но и простым уже не является.

    Reply
  5. kiruha

    А если сравнить с например

    http://www.sql.ru/forum/224064/prostye-chisla

    Reply
  6. vadim1011985
    Среди чисел в колонке Произведение есть повторяющиеся. Это числа 4,6 и 9.

    Не нашел повторения числа 4 в приведенной таблице , но есть повторения числа 8 Проверьте — возможно опечатка

    Reply
  7. scientes

    (6) Да, это ошибка. Таблица была неполная. 1*4=4: 2*2=4

    Reply
  8. scientes

    (5)Вот одно из правильных решений http://jdevnotes.blogspot.ru/2009/06/sql.html

    Reply
  9. bulpi

    «ВЫРАЗИТЬ(A/Б КАК ЧИСЛО(19,2))*Б = Б

    Если это выражение истинно, то Б является делителем числа А.»

    Это ошибка, исправьте на

    ВЫРАЗИТЬ(A/Б КАК ЧИСЛО(19,0))*Б = А

    Reply
  10. scientes

    (9) Да Вы правы, это ошибка. Исправил. Благодарю за замечание.

    Reply
  11. ildarovich

    Вот такой запрос находит все нечетные простые числа на отрезке [1 … 131073] за 1,308 сек. Используется решето Сундарама. Параметрами является N, которое задает интервал поиска как [1 … 2N+1] и заранее вычисленное значение (SQRT(2N+1)-1)/2.

    ВЫБРАТЬ
    0 КАК Х
    ПОМЕСТИТЬ Регистр1
    ОБЪЕДИНИТЬ
    ВЫБРАТЬ
    1
    ;
    ВЫБРАТЬ
    Младшие.Х + 2 * Старшие.Х КАК Х
    ПОМЕСТИТЬ Регистр2
    ИЗ
    Регистр1 КАК Младшие,
    Регистр1 КАК Старшие
    ;
    ВЫБРАТЬ
    Младшие.Х + 4 * Старшие.Х КАК Х
    ПОМЕСТИТЬ Регистр4
    ИЗ
    Регистр2 КАК Младшие,
    Регистр2 КАК Старшие
    ;
    ВЫБРАТЬ
    Младшие.Х + 16 * Старшие.Х КАК Х
    ПОМЕСТИТЬ Регистр8
    ИЗ
    Регистр4 КАК Младшие,
    Регистр4 КАК Старшие
    ;
    ВЫБРАТЬ
    Младшие.Х + 256 * Старшие.Х + 1 КАК Х
    ПОМЕСТИТЬ Регистр16
    ИЗ
    Регистр8 КАК Младшие,
    Регистр8 КАК Старшие
    ;
    
    ////////////////////////////////////////////////////////////­////////////////////
    ВЫБРАТЬ
    2 * ВложенныйЗапрос.Х + 1 КАК ПростоеЧисло
    ИЗ
    (ВЫБРАТЬ
    А.Х + Б.Х + 2 * А.Х * Б.Х КАК Х
    ИЗ
    Регистр16 КАК А
    ВНУТРЕННЕЕ СОЕДИНЕНИЕ Регистр16 КАК Б
    ПО (Б.Х МЕЖДУ А.Х И (&Эн — А.Х) / (2 * А.Х + 1))
    ГДЕ
    А.Х <= &КореньИз_ДваЭнПлюс1_Минус1_РазделитьНа2
    
    ОБЪЕДИНИТЬ ВСЕ
    
    ВЫБРАТЬ
    А.Х
    ИЗ
    Регистр16 КАК А
    ГДЕ
    А.Х <= &Эн) КАК ВложенныйЗапрос
    
    СГРУППИРОВАТЬ ПО
    ВложенныйЗапрос.Х
    
    ИМЕЮЩИЕ
    КОЛИЧЕСТВО(*) = 1
    
    УПОРЯДОЧИТЬ ПО
    ПростоеЧисло

    Показать

    Первая часть запроса, формирующая ряд чисел, взята отсюда: Порождающий запрос. «Все нечетные простые числа» означает, что к результату (к полученному множеству простых чисел) нужно добавить единственное простое четное число 2.

    Reply
  12. scientes

    (11) Классно, все работает ! Сундарама молодец !

    Reply
  13. ildarovich

    (0) Понял, наконец, что меня смущает в варианте 2. Вся эта возня с квадратами ни к чему. Достаточно добавить поле ХХ (квадрат) к таблице чисел, что можно сделать (кажется) прямо при чтении таблицы в запрос. Тогда весь необходимый код уложится в минимум строк:

    ВЫБРАТЬ
    Числа.НатуральноеЧисло КАК Х,
    Числа.НатуральноеЧисло * Числа.НатуральноеЧисло КАК ХХ
    ПОМЕСТИТЬ ВТ
    ИЗ
    &Числа КАК Числа
    ;
    
    ////////////////////////////////////////////////////////////­////////////////////
    ВЫБРАТЬ
    Делимое.Х КАК ПростоеЧисло
    ИЗ
    ВТ КАК Делимое
    ВНУТРЕННЕЕ СОЕДИНЕНИЕ ВТ КАК Делитель
    ПО Делимое.Х >= Делитель.ХХ
    И ((ВЫРАЗИТЬ(Делимое.Х / Делитель.Х КАК ЧИСЛО(19, 0))) = Делимое.Х / Делитель.Х)
    
    СГРУППИРОВАТЬ ПО
    Делимое.Х
    
    ИМЕЮЩИЕ
    КОЛИЧЕСТВО(*) = 1

    Показать

    Условие делимости так написано нарочно, в надежде на то, что Делимое.Х / Делитель.Х будет вычисляться один раз.

    Reply
  14. scientes

    (13) Да, все правильно. так быстрее.

    Reply
  15. Кадош

    У вас ошибка в заголовке. Правильно — «Как получить список простых чисел в запросе и самое главное зачем?»

    Reply
  16. 🅵🅾️🆇

    (1) Что не так с оформлением?

    Reply
  17. 🅵🅾️🆇

    (15)

    Reply
  18. Filipp_Hardcorov

    (16)

    1С. Общие требования к построению конструкций встроенного языка:

    1. В конструкциях встроенного языка ключевые слова пишутся канонически (как в документации или Синтакс-помощнике).

    Правильно:

    КонецЕсли

    Неправильно:

    конецЕсли, КОНЕЦЕСЛИ, конецесли, Конецесли.

    2. При следовании друг за другом нескольких операторов присваивания, допускается выравнивать их следующим образом:

    ДиалогВыбора.ПолноеИмяФайла = ИмяФайла;

    ДиалогВыбора.Каталог = ИмяПути; (тут должно быть выровнено по «=», но пробелы стираются при добавлении коммента)

    Если не соблюдать эти 2 простых правила, то код будет резать глаза.

    Reply
  19. 🅵🅾️🆇

    (18) Глупости.

    Возможно Вы один из тех людей, что следуют дзен-правилам 1с и дорожат сертификатами, но не все таковыми являются.

    То что 1с хочет навязать PascalCase не делает людей использующих camelCase неполноценными.

    1) Я, например, оформляю код так и не вижу в нем ничего плохого и нечитабельного:

    ПОКА А ЦИКЛ // <== Корневой цикл/условие с вложенными циклами/условиями обозначаю строчными
    Для Каждого Б Из В Цикл
    Если Г Тогда
    мФруктов = СтрРазделить(«Яблоки,Апельсины,Мандарины», «,»);
    КонецЕсли; // Если Г
    КонецЦикла; // Для Каждого Б Из В
    КОНЕЦЦИКЛА; // ПОКА А
    

    Показать

    Если работодатель будет против — буду делать в соответсвии корпоративным нормативом (ну или уволюсь).

    2) Табуляции это, конечно, здорово, сам их использую на винде.

    Только вот под линем они могут пойти по огромной такой [3,14]зде и выглядеть будет крайне отвратно.

    Вы же доподлино не знаете под какой платформой сидит человек для подобных суждений, верно?

    Алсо, на инфостарте табуляции в кодбоксе также отображаются криво, оценить можете в сниппетах под спойлерами всю плачевность ситуации: ТЫК

    ВЫВОД: не стоит быть столь категоричным и плясать под дудку 1с.

    Все же главное читабельность. А агрессивные работодатели с еб@нутыми требованиями/придирками получат соответсвующих специалистов.

    БОНУС: В школах-институтах нас по рукам за GOTO били, так может теперь и Перейти (GOTO) не использовать?

    Давненько не видел в чужих публикациях этого оператора, хотя его можно очень толково применять.

    Reply
  20. starik-2005

    Интересное упражнение. Поколдовал в конфегураторе и что-то такое получилось:

     Запрос = Новый Запрос(
    «ВЫБРАТЬ
    | 0 КАК Поле1
    |ПОМЕСТИТЬ ВТ1
    |
    |ОБЪЕДИНИТЬ ВСЕ
    |
    |ВЫБРАТЬ
    | 1
    |
    |ОБЪЕДИНИТЬ ВСЕ
    |
    |ВЫБРАТЬ
    | 2
    |
    |ОБЪЕДИНИТЬ ВСЕ
    |
    |ВЫБРАТЬ
    | 3
    |;
    |
    |////////////////////////////////////////////////////////////­////////////////////
    |ВЫБРАТЬ
    | ВТ.Поле1 + ВТ1.Поле1 * 4 + ВТ2.Поле1 * 16 + ВТ3.Поле1 * 64 + ВТ4.Поле1 * 256 + 2 КАК Число
    |ПОМЕСТИТЬ ВТСт
    |ИЗ
    | ВТ1 КАК ВТ,
    | ВТ1 КАК ВТ1,
    | ВТ1 КАК ВТ2,
    | ВТ1 КАК ВТ3,
    | ВТ1 КАК ВТ4
    |;
    |
    |////////////////////////////////////////////////////////////­////////////////////
    |ВЫБРАТЬ РАЗЛИЧНЫЕ
    | ВТК.Число * ВТСт.Число КАК Число
    |ПОМЕСТИТЬ ВТНеПростые
    |ИЗ
    | ВТСт КАК ВТСт,
    | ВТСт КАК ВТК
    |ГДЕ
    | ВТК.Число * ВТСт.Число < &Предел
    |;
    |
    |////////////////////////////////////////////////////////////­////////////////////
    |ВЫБРАТЬ
    | ВТСт.Число КАК Число
    |ИЗ
    | ВТСт КАК ВТСт
    |ГДЕ
    | ВТСт.Число < &Предел И НЕ ВТСт.Число В
    |    (ВЫБРАТЬ
    |     ВТНеПростые.Число
    |    ИЗ
    |     ВТНеПростые)
    |
    |
    |УПОРЯДОЧИТЬ ПО
    | ВТСт.Число»);
    Запрос.УстановитьПараметр(«Предел», Предел);
    Таблица.Загрузить(
    Запрос.Выполнить().Выгрузить()
    );
    
    

    Показать

    Кстати, этот запрос легко модицифировать и получить все натуральные делители для нужного числа, а кто-то тут не так давно отказывался от решения подобной задачи на собеседовании )))

    Reply
  21. ildarovich

    У меня тоже решето Аткина проигрывает решету Сундарама. Вот моя реализация:

    ВЫБРАТЬ
    0 КАК Х
    ПОМЕСТИТЬ Регистр1
    
    ОБЪЕДИНИТЬ
    
    ВЫБРАТЬ
    1
    ;
    ВЫБРАТЬ
    Младшие.Х + 2 * Старшие.Х КАК Х
    ПОМЕСТИТЬ Регистр2
    ИЗ
    Регистр1 КАК Младшие,
    Регистр1 КАК Старшие
    ;
    ВЫБРАТЬ
    Младшие.Х + 4 * Старшие.Х КАК Х
    ПОМЕСТИТЬ Регистр4
    ИЗ
    Регистр2 КАК Младшие,
    Регистр2 КАК Старшие
    ;
    ВЫБРАТЬ
    Младшие.Х + 16 * Старшие.Х КАК Х
    ПОМЕСТИТЬ Регистр8
    ИЗ
    Регистр4 КАК Младшие,
    Регистр4 КАК Старшие
    ;
    ВЫБРАТЬ
    1 + Младшие.Х + 256 * Старшие.Х КАК Х
    ПОМЕСТИТЬ Ряд
    ИЗ
    Регистр8 КАК Младшие,
    Регистр2 КАК Старшие
    ГДЕ
    1 + Младшие.Х + 256 * Старшие.Х <= &КореньИзГраницы
    ;
    
    ////////////////////////////////////////////////////////////­////////////////////
    ВЫБРАТЬ
    КвадратичныеФормы.Х,
    КвадратичныеФормы.Х * КвадратичныеФормы.Х КАК ХХ
    ПОМЕСТИТЬ Кандидаты
    ИЗ
    (ВЫБРАТЬ
    Случай1.Х КАК Х
    ИЗ
    (ВЫБРАТЬ
    4 * А.Х * А.Х + Б.Х * Б.Х КАК Х
    ИЗ
    Ряд КАК А,
    Ряд КАК Б) КАК Случай1
    ГДЕ
    СЕКУНДА(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1, 1, 1), СЕКУНДА, Случай1.Х * 5)) В (5, 25)
    
    ОБЪЕДИНИТЬ ВСЕ
    
    ВЫБРАТЬ
    Случай2.Х
    ИЗ
    (ВЫБРАТЬ
    3 * А.Х * А.Х + Б.Х * Б.Х КАК Х
    ИЗ
    Ряд КАК А,
    Ряд КАК Б) КАК Случай2
    ГДЕ
    СЕКУНДА(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1, 1, 1), СЕКУНДА, Случай2.Х * 5)) = 35
    
    ОБЪЕДИНИТЬ ВСЕ
    
    ВЫБРАТЬ
    Случай3.Х
    ИЗ
    (ВЫБРАТЬ
    3 * А.Х * А.Х — Б.Х * Б.Х КАК Х
    ИЗ
    Ряд КАК А
    ВНУТРЕННЕЕ СОЕДИНЕНИЕ Ряд КАК Б
    ПО А.Х > Б.Х) КАК Случай3
    ГДЕ
    СЕКУНДА(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1, 1, 1), СЕКУНДА, Случай3.Х * 5)) = 55) КАК КвадратичныеФормы
    ГДЕ
    СЕКУНДА(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1, 1, 1), СЕКУНДА, КвадратичныеФормы.Х * 12)) > 0
    И КвадратичныеФормы.Х <= &Граница
    
    СГРУППИРОВАТЬ ПО
    КвадратичныеФормы.Х
    
    ИМЕЮЩИЕ
    СЕКУНДА(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1, 1, 1), СЕКУНДА, КОЛИЧЕСТВО(*) * 30)) = 30
    ;
    
    ////////////////////////////////////////////////////////////­////////////////////
    ВЫБРАТЬ
    Делимое.Х КАК Х
    ИЗ
    Кандидаты КАК Делимое
    ЛЕВОЕ СОЕДИНЕНИЕ Кандидаты КАК Делитель
    ПО (Делитель.ХХ <= Делимое.Х)
    И ((ВЫРАЗИТЬ(Делимое.Х / Делитель.Х КАК ЧИСЛО(15, 0))) = Делимое.Х / Делитель.Х)
    ГДЕ
    Делитель.Х ЕСТЬ NULL
    
    ОБЪЕДИНИТЬ
    
    ВЫБРАТЬ
    2
    
    ОБЪЕДИНИТЬ
    
    ВЫБРАТЬ
    3
    
    ОБЪЕДИНИТЬ
    
    ВЫБРАТЬ
    5
    
    УПОРЯДОЧИТЬ ПО
    Делимое.Х

    Показать

    для сравнения. Тут вроде бы нечего дальше оптимизировать, а работает примерно в 1,6 раза дольше, чем Сундарама, который еще можно чуть-чуть «подкрутить» в плане оптимизации (за счет проверки пустых мест рядом с четными, а не соединением с таблицей чисел). Это странно. Алгоритм Аткина вообще-то считается более быстрым.

    Reply
  22. boln

    (18)

    ДиалогВыбора.ПолноеИмяФайла = ИмяФайла;

    ДиалогВыбора.Каталог = ИмяПути; (тут должно быть выровнено по «=», но пробелы стираются при добавлении коммента)

    Отнюдь не «должно», хотя и красиво выглядит. И есть довольно много противников такого выравнивания (я лично к ним не отношусь).

    А вот по первому пункту согласен.

    Reply
  23. Filipp_Hardcorov

    (19)

    Я не следую всем правилам, просто когда все в едином стиле — это воспринимается лучше зрительно и говорит о том, что программист писал не на отъе***, а старался.

    Зачем вы тогда по-русски пишете сейчас без ошибок, со знаками препинания, и предложения начинаете с большой буквы?

    Reply
  24. Filipp_Hardcorov

    (22)

    Во-первых выглядит симпатичнее, а во-вторых сразу понятно, что это блок заполнения какой-то структуры.

    Т.е. если тебе нужно что-то исправить, не относящееся к этому, можно много строк просто пропустить глазами, что ускоряет восприятие «чужого» кода, да и своего тоже.

    Reply
  25. 🅵🅾️🆇

    (24)

    Только вот под линем они могут пойти по огромной такой [3,14]зде и выглядеть будет крайне отвратно.

    Алсо, на инфостарте табуляции в кодбоксе также отображаются криво
    Reply
  26. boln

    (24)

    Во-первых выглядит симпатичнее, а во-вторых сразу понятно, что это блок заполнения какой-то структуры.

    Т.е. если тебе нужно что-то исправить, не относящееся к этому, можно много строк просто пропустить глазами, что ускоряет восприятие «чужого» кода, да и своего тоже.

    Угу, я тоже так свой код оформляю. Сделал даже программый «выравниватель» — и для EDT:

    https://infostart.ru/public/569440/

    и для Конфигуратора:

    https://www.youtube.com/watch?v=R8WB-Y24w_A&feature=youtu.be

    Но есть жесткие противники этого. На партнерке даже мини-холивар был по поводу «выравнивания». Раньше в Рекомендациях 1С по оформлению кода был этот пункт, а сейчас убрали вроде.

    Reply
  27. Кадош

    (17)Показ лаборатории иностранному гостю. «А вот тут мы вырастили биллиардный шар с волосами.»

    «Зачем?» — «Не знаю, но было очень трудно»

    Reply
  28. scientes

    (21) Можно немного увеличить скорость выполнения запроса использованием конструкций

    Reply
  29. ildarovich

    (28) «конструкций …» — что-то здесь пропущено

    Reply
  30. Saint13

    Возникает вопрос:

    В реальной жизни есть боевая задача по данной теме?

    (для 1С)

    Reply
  31. scientes

    (29)

    МЕСЯЦ(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1, 12, 1), МЕСЯЦ, Случай1.Х )) В (1,5)

    МЕСЯЦ(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1, 12, 1), МЕСЯЦ, Случай2.Х )) = 7

    МЕСЯЦ(ДОБАВИТЬКДАТЕ(ДАТАВРЕМЯ(1, 12, 1), МЕСЯЦ, Случай3.Х )) = 11

    Правда, для больших чисел программа начинает ругаться на переполнение. Я так понял, поэтому и применяется вариант с секундами.

    Reply
  32. ildarovich

    (31) Да, но и с секундами будет когда-нибудь ругаться. Там предел 2#k8SjZc9Dxk32 — 1 или 2#k8SjZc9Dxk31 — 1. Это примерно миллиард. Надеюсь, никто не додумается из миллиарда простые числа в запросе определять. Так как будет уже не с временем (оно почти линейно растет, поэтому миллиард за 16000 секунд должен посчитаться), а с памятью проблемы.

    Reply
  33. Eret1k

    + за

    Разумеется, ни в одной типовой конфигурации такие задачи не встречаются. Но подобный вопрос может встретиться на собеседовании при приеме на работу.
    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *