поиск элементов справочника7

  • Автор темы Автор темы kleo
  • Дата начала Дата начала
K

kleo

Люди добрые, подскажите, пожалуйста, как найти элементы справочника с одиннаковым наименованием, а потом среди них один элемент с нужными мне реквизитами!! Заранее очень спасибо!!!
 
Например, простым перебором.
 
Табло=СоздатьОбъект("ТаблицаЗначения");
Табло.НоваяКолонка("Элемент");
Табло.НоваяКолонка("НужныйРеквизит");
Наим = "одинаковое наименование";

Запрос = СоздатьОбъект("Запрос");

ТекстЗапроса =
"//{{ЗАПРОС(Сформировать)
|Элем = Справочник.ХХХ.ТекущийЭлемент;
|Наименование = Справочник.ХХХ.Наименование;
|Условие (Найти(Наименование,Наим)>0);
|Группировка Элем без групп;
|";

Если Запрос.Выполнить(ТекстЗапроса) = 0 Тогда
Возврат;
КонецЕсли;

Пока Запрос.Группировка(1) = 1 Цикл
Табло.НоваяСтрока();
Табло.Элемент = Запрос.Элем;
Табло.НужныйРеквизит = Запрос.Элем.НужныйРеквизит
КонецЦикла;

НужныйРеквизитПоиск = """"";

Стр = "";
Если Табло.НайтиЗначение(НужныйРеквизитПоиск,Стр,"НужныйРеквизит")=1 Тогда
НужныйЭлементПоПоиску = Табло.ПолучитьЗначение(Стр,"Элемент");
КонецЕсли;
 
Насчет перебора предложение не пойдет, так как займет очень много времени, а вот запрос сейчас испробую. Спасибо большое!!!!!
 
Можешь еще глянуть метод справочника НайтиПоНаименованию().
 
... и наткнувшись на нужное наименование, проверять нужные реквизиты, пока совпадает наименование
 
Можно еще попробовать метод ВыбратьЭлементыПоРеквизиту, и из выборки выбрать нужный.
Но лучше всего - запросом.
 
Мы в соцсетях:

Взломай свой первый сервер и прокачай скилл — Начни игру на HackerLab

🚀 Первый раз на Codeby?
Гайд для новичков: что делать в первые 15 минут, ключевые разделы, правила
Начать здесь →
🔴 Свежие CVE, 0-day и инциденты
То, о чём ChatGPT ещё не знает — обсуждаем в реальном времени
Threat Intel →
💼 Вакансии и заказы в ИБ
Pentest, SOC, DevSecOps, bug bounty — работа и проекты от проверенных компаний
Карьера в ИБ →

HackerLab