Универсальная многопоточная обработка данных 1С

17.07.25

Задачи пользователя - Подбор и обработка объектов

Нужно быстро обработать какие-то данные, а подходящей многопоточной обработки нет?

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
Универсальная многопоточная обработка данных 1С от 03.07.2025
.epf 23,46Kb ver:11.06.2024
53 2 450 руб. Купить

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

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

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

Однажды потребовалось неоднократно помечать на удаление 3500 документов. Процедура долгая, выполнялась примерно 1 час.

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

За основу взята бесплатно распространяемая обработка //infostart.ru/1c/tools/1808052/.

Обработка позволяет написать коды процедур выборки данных и обработки данных прямо в пользовательском режиме, без использования конфигуратора.

Обработкой можно пользоваться как внешней, так и встроить в доп обработки. В любом варианте запуска фоновое выполнение будет работать.

Для удобства добавлены:

  1. Возможность оставить комментарий в отдельном поле.
  2. Конструктор запроса в "Код выборки данных". Можно выделить существующий текст запроса и в конструкторе он сразу подтянется. Либо не выделять текст и создать новый текст запроса.
  3. Возможность сохранять и загружать настройки обработки. В файл TXT будет записана структура со свойствами "КоличествоПотоков, КодВыборкиДанных, КодОбработкиДанных, Комментарий" в формате XML (ОбщегоНазначения.ЗначениеВСтрокуXML)


Небольшое пояснение:

Поле "Код выборки данных" должно содержать код, который в переменную "ТаблицаДляОбработки" поместит таблицу значений с данными, которые нужно будет обработать процедурой "Код обработки данных".

*После выполнения кода обработки в таблицу значений будут добавлены служебные колонки "ИД, (Пометка) Обработать, Результат, Описание ошибки".

Поле "Код обработки данных" должно содержать код, который будет выполнять операции с данными. Обход производится построчно. В переменной "ЭлементКоллекции" содержится данные текущей строки таблицы значений.

С помощью данной обработки помечено на удаление 3500 документов за 5 минут (использовав 50 потоков), вместо 1 часа в одном потоке
 

 

 

Для функционирования обработки требуется БСП.

Тестировалось на ЗУП КОРП 3.1.29.

 
 Новое в версии от 03.07.2025
  • Теперь можно настраивать, как часто обновляется статус выполнения (например, раз в 5 секунд вместо 1).
  • Сообщения о ходе и завершении обработки стали информативнее.
  • Появилась возможность сохранять все настройки обработки в файл и потом быстро их загружать обратно. Это удобно, если вы часто используете одни и те же параметры или хотите поделиться настройками с коллегой.
  • Появился отдельный параметр для задания имени фонового задания.
  • Все параметры и коды по умолчанию стали более наглядными и адаптированы под реальные задачи.
  • Результат обработки теперь можно задавать явно. Внутри кода обработки теперь можно присвоить переменной "Результат" нужное значение (например, текст или статус). Если не присвоить — будет как раньше: просто "Обработан". Это удобно, если нужно вернуть подробный результат по каждому объекту.
  • Для каждого потока теперь формируется уникальное имя задания (например, "Импорт данных.Поток 2"), что облегчает отслеживание и анализ. Это особенно полезно, если одновременно запускается несколько потоков.
  • Более чистый и понятный код. Убраны лишние транзакции вокруг обработки каждого объекта (раньше был НачатьТранзакцию()/ЗафиксироватьТранзакцию(), теперь этого нет). Транзакцию необходимо ставить самостоятельно.
  • Более гибкая обработка ошибок.Если при обработке объекта возникла ошибка, результат теперь всегда фиксируется как "Ошибка", а описание ошибки сохраняется. Это облегчает разбор проблем после массовой обработки.
 

 

Проверено на следующих конфигурациях и релизах:

  • 1С:Библиотека стандартных подсистем, редакция 3.1, релизы 3.1.10.191
  • Зарплата и управление персоналом, редакция 3.1, релизы 3.1.29.38

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

обработка многопоточная обработка фоновая обработка внешняя многопоточная обработка

См. также

SALE! 50%

Журналы и реестры данных Подбор и обработка объектов Бухгалтер Пользователь 1С v8.3 Управляемые формы 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:Библиотека стандартных подсистем 1С:ERP Управление предприятием 2 1С:Зарплата и кадры государственного учреждения 3 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 1С:Розница 2 1С:Розница 3.0 Платные (руб)

Журнал содержит все созданные документы в конфигурации. Позволяет выполнять стандартные действия с документами (создание, удаление, проведение), устанавливать отбор по видам документов, реквизитам документов, распечатывать печатные формы, формировать реестр документов, выполнять групповые обработки.

4800 2400 руб.

07.02.2025    2324    51    35    

9

Поиск данных ЭДО и ОФД Подбор и обработка объектов 1С v8.3 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Поиск номенклатуры при сопоставлении в ЭДО не интуитивный, не настраиваемый и просто неудобный. Данное решение - это альтернативный вариант расширенного поиска и сопоставления номенклатуры для 1С, который подключается в качестве расширения и решает эту проблему.

10000 руб.

10.04.2025    590    1    1    

1

Подбор и обработка объектов Бухгалтер 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

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

6000 руб.

29.06.2015    46274    91    18    

106

Подбор и обработка объектов Бухгалтер Бухгалтерский учет 1С:Бухгалтерия 2.0 1С:Бухгалтерия государственного учреждения 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Бюджетный учет Платные (руб)

Данная обработка предлагается для случаев, когда бывает необходимо изменить какой-либо реквизит в группе проводок, отобранных по определенному набору полей, за определенный период, с определенным типом документа-регистратора. Предлагается четыре варианта обработки для конфигураций: БП 2.0, БП 3.0, БГУ 1.0, БГУ 2.0.

2400 руб.

30.05.2016    29511    30    0    

50

Подбор и обработка объектов Программист Бухгалтер Пользователь 1С v8.3 1С:Бухгалтерия 3.0 Абонемент ($m)

Данная обработка может быть полезна тем, кто хочет сделать более точечную замену объектов, когда заказчику необходимо заменить что-то только в определенном виде документа (справочника) с определенным отбором по реквизитам.

1 стартмани

09.05.2025    790    30    Rafael-87    5    

6

Подбор и обработка объектов Программист Бухгалтер Пользователь 1С v8.3 Абонемент ($m)

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

10 стартмани

29.04.2025    3487    7    DmitryKSL    7    

17

Подбор и обработка объектов Бухгалтер Пользователь 1С v8.3 1С:Управление нашей фирмой 3.0 Управленческий учет Абонемент ($m)

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

1 стартмани

21.02.2025    664    4    andrey7617    0    

4

Подбор и обработка объектов Программист 1С v8.3 Россия Абонемент ($m)

Массовая работа с объектами типовыми методами платформы 1С.

10 стартмани

13.12.2024    1121    5    nomad_irk    5    

4
Отзывы
5. mistervoron 11 14.06.24 12:35 Сейчас в теме
Очень интересная идея и обработка! Спасибо!
Остальные комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. fomix 33 14.06.24 04:01 Сейчас в теме
Однажды потребовалось неоднократно помечать на удаление 3500 документов. Процедура долгая, выполнялась примерно 1 час.
. А сколько времени это заняло с помощью данной обработки?
3. maslyann 88 14.06.24 09:12 Сейчас в теме
(1) заняло 5 минут с помощью 50 потоков. Разница очень большая
2. BackinSoda 14.06.24 09:10 Сейчас в теме
3500 за час вроде как не долго
4. maslyann 88 14.06.24 09:14 Сейчас в теме
(2)Просто эту операция мне нужно было проделать раз 7 (пометить на удаление 3500 документов). Семь часов времени непозволительно много.
А многопоточная обработка в 50 потоков справилась за 5 минут. Разница очевидна.
mistervoron; cis; +2 Ответить
5. mistervoron 11 14.06.24 12:35 Сейчас в теме
Очень интересная идея и обработка! Спасибо!
6. пользователь 19.06.24 12:51
Сообщение было скрыто модератором.
...
Оставьте свое сообщение