Оптимизация функции ПодставитьПараметрыВСтроку

23.04.12

Разработка - Универсальные функции

В типовых конфигурациях часто используется функция ПодставитьПараметрыВСтроку. Если параметров несколько, эту функцию использовать достаточно удобно. Но работает она довольно медленно - еще бы, ведь в ней каждый раз выполняется полный перебор всех символов в стоке. При активной работе со строками падение производительности становится заметным.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Тест стандартной и оптимизированной функции
.erf 7,03Kb
7 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Конечно, можно пользоваться регулярными выражениями... Но с ними нужно разбираться, отлаживать. Поэтому я решил попросту оптимизировать существующую функцию. Первым делом откажемся от перебора - ведь в 1С есть функцкция Найти(), которая работае достаточно быстро. Не буду утомлять, сразу напишу результат:

На моем ноутбуке выполнение 10 000 раз стандартной функции занимает 37 секунд, оптимизированной - меньше секунды.

 
 Функция ПодставитьПараметрыВСтроку(Знач СтрокаПодстановки,
    Знач
Параметр1,    Знач Параметр2 = Неопределено, Знач Параметр3 = Неопределено,
    Знач
Параметр4 = Неопределено, Знач Параметр5 = Неопределено, Знач Параметр6 = Неопределено,
    Знач
Параметр7 = Неопределено, Знач Параметр8 = Неопределено, Знач Параметр9 = Неопределено) Экспорт

    Если
СтрокаПодстановки = Неопределено ИЛИ СтрДлина(СтрокаПодстановки) = 0 Тогда
        Возврат
"";
    КонецЕсли;

   
Результат = "";

   
НачПозиция = 1;

   
Позиция = Найти(СтрокаПодстановки, "%");

    Пока
Позиция > 0 Цикл
       
СимволСтроки = Сред(СтрокаПодстановки, Позиция, 1);
        Если
СимволСтроки <> "%" Тогда
           
Позиция = Позиция + 1;
            Продолжить;
        КонецЕсли;
       
Результат = Результат + Сред(СтрокаПодстановки, НачПозиция, Позиция - НачПозиция);

       
Позиция = Позиция + 1;
       
СимволСтроки = Сред(СтрокаПодстановки, Позиция, 1);

        Если
СимволСтроки = "1" Тогда
           
ЗначениеПараметра = Параметр1;
        ИначеЕсли
СимволСтроки = "2" Тогда
           
ЗначениеПараметра = Параметр2;
        ИначеЕсли
СимволСтроки = "3" Тогда
           
ЗначениеПараметра = Параметр3;
        ИначеЕсли
СимволСтроки = "4" Тогда
           
ЗначениеПараметра = Параметр4;
        ИначеЕсли
СимволСтроки = "5" Тогда
           
ЗначениеПараметра = Параметр5;
        ИначеЕсли
СимволСтроки = "6" Тогда
           
ЗначениеПараметра = Параметр6;
        ИначеЕсли
СимволСтроки = "7" Тогда
           
ЗначениеПараметра = Параметр7;
        ИначеЕсли
СимволСтроки = "8" Тогда
           
ЗначениеПараметра = Параметр8;
        ИначеЕсли
СимволСтроки = "9" Тогда
           
ЗначениеПараметра = Параметр9;
        ИначеЕсли
СимволСтроки = "%" Тогда
           
ЗначениеПараметра = "%";
        Иначе
            ВызватьИсключение
НСтр("ru='Входная строка СтрокаПодстановки имеет неверный формат: %';uk='Вхідний рядок Строкаподстановки має невірний формат: %'" + ЗначениеПараметра);
        КонецЕсли;
        Если
ЗначениеПараметра = Неопределено Тогда
           
ЗначениеПараметра = "";
        Иначе
           
ЗначениеПараметра = Строка(ЗначениеПараметра);
        КонецЕсли;
       
Результат = Результат + ЗначениеПараметра;
       
Позиция = Позиция + 1;
       
СтрокаПодстановки = Сред(СтрокаПодстановки, Позиция);
       
Позиция = Найти(СтрокаПодстановки, "%");
    КонецЦикла;

    Если (
НачПозиция <= СтрДлина(СтрокаПодстановки)) Тогда       

        Результат = Результат + Сред(СтрокаПодстановки, НачПозиция, СтрДлина(СтрокаПодстановки) - НачПозиция + 1);
    КонецЕсли;

    Возврат
Результат;
КонецФункции

Вступайте в нашу телеграмм-группу Инфостарт

См. также

Загрузка и выгрузка в Excel Универсальные функции Программист 1С:Предприятие 8 Россия Бесплатно (free)

Описанный ниже подход позволяет в три шага заполнять формулы в Excel файлы, вне зависимости от ОС сервера (MS Windows Server или Linux). Подход подразумевает отказ от работы с COM-объектом в пользу работы через "объектную модель документа" (DOM).

30.10.2025    3465    Abysswalker    8    

45

Универсальные функции Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

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

14.05.2025    6411    DeerCven    15    

57

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    48900    dimanich70    83    

170

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    7323    6    John_d    13    

59

Универсальные функции Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    61139    atdonya    31    

69

Универсальные функции Программист 1С:Предприятие 8 Бесплатно (free)

На заключительных этапах, когда идет отладка или доработка интерфейса, необходимо много раз переоткрыть внешний объект. Вот один из способов автоматизации этого.

30.11.2023    9120    ke.92@mail.ru    17    

68
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Поручик 4600 23.04.12 10:21 Сейчас в теме
(0) Это как понимать?

    Если (НачПозиция         Результат = Результат + Сред(СтрокаПодстановки, НачПозиция, СтрДлина(СтрокаПодстановки) - НачПозиция + 1);
    КонецЕсли;
3. curdate 54 23.04.12 10:30 Сейчас в теме
(1) Поручик, Первый раз "Разукрашкой" пользовался, вот и накосячил чуть. Спасибо, сейчас исправлю.
2. Lyns_owner 356 23.04.12 10:27 Сейчас в теме
Прикольная функция... а что так мало параметров принимает?)) Сделай хотя бы 500... xD
4. ediks 338 23.04.12 10:31 Сейчас в теме
(2) Ну, самом деле функция очень часто используется в БСП (по крайней мере) и там действительно 9 параметров. Автор попытался оптимизировать ее, но неудачно выложил код, как верно заметил Поручик в (1)
5. Поручик 4600 23.04.12 12:21 Сейчас в теме
(2) Для количества параметров более 9 надо усложнять алгоритм разбора, а на практике используется максимум 4-5.
Для отправки сообщения требуется регистрация/авторизация