Поиск по произвольным частям текста

07.04.19

Задачи пользователя - Поиск данных

Часто мы точно не знаем точное и полное название элемента справочника. Но знаем примерно его части. Например, хотим найти валюту "Доллар США", но помним только что название точно содержит два слова "олл" и "ША".

Скачать файл

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

Наименование По подписке [?] Купить один файл
Поиск по произвольным частям текста, демо-база
.dt 273,95Kb
3
3 Скачать (1 SM) Купить за 1 850 руб.

Демо-база работает на платформе 1с.8.3.12 и выше.

Часто мы точно не знаем точное и полное название элемента справочника. Но знаем примерно его части. Например, хотим найти валюту "Доллар США", но помним только что название точно содержит два слова "олл" и "ША".

Паттерн получения запроса:

Функция ПолучитьЗапросНаПоискПоЛексемамВСправочнике(Текст,Справочник="Валюты",Тип="Справочник",Поле="Наименование") Экспорт
	
	// может будет медленно, когда ссылок будет много.
	// разделим строку поиска на лексемы через пробел
	МассивЛексем	= СтроковыеФункцииКлиентСервер.РазложитьСтрокуВМассивПодстрок(Текст," ");
	Для Счетчик = 0 По МассивЛексем.Количество()-1 Цикл
		МассивЛексем[Счетчик]	= "%"+МассивЛексем[Счетчик]+"%";
	КонецЦикла;
	//Если СтрокаМассива.Количество()>5 Тогда
	//	Сообщить("Поиск будет произведен только по первым пяти частям строки.",СтатусСообщения.Внимание);
	//КонецЕсли;
	
	Запрос	= Новый Запрос;
	Запрос.УстановитьПараметр("Лексема0",МассивЛексем[0]);
	Запрос.УстановитьПараметр("Лексема0Р",ВосстановитьРаскладку(МассивЛексем[0]));
	Запрос.Текст	= 
		"ВЫБРАТЬ различные
		|	Справочник.Ссылка,Справочник.ПометкаУдаления
		|ИЗ
		|	Справочник.Валюты КАК Справочник
		|ГДЕ
		|	(Справочник.Наименование ПОДОБНО &Лексема0
		|	ИЛИ Справочник.Наименование ПОДОБНО &Лексема0Р)"
		;
		
	Для Счетчик = 1 По МассивЛексем.Количество()-1 Цикл
		Запрос.УстановитьПараметр("Лексема"+Счетчик+"",МассивЛексем[Счетчик]);
		Запрос.УстановитьПараметр("Лексема"+Счетчик+"Р",ОбщегоНазначения.ВосстановитьРаскладку(МассивЛексем[Счетчик]));
		Запрос.Текст	= Запрос.Текст+"
			|И (Справочник.Наименование ПОДОБНО &Лексема"+Счетчик+"
			|	ИЛИ Справочник.Наименование ПОДОБНО &Лексема"+Счетчик+"Р)";
	КонецЦикла;
		
	Запрос.Текст	= СтрЗаменить(Запрос.Текст,"Валюты",Справочник);	
	Запрос.Текст	= СтрЗаменить(Запрос.Текст,"Справочник",Тип);	
	Запрос.Текст	= СтрЗаменить(Запрос.Текст,"Наименование",Поле);
		
	Возврат Запрос;	
	
КонецФункции

 

Использование запроса в управляемых формах - подключение к полю выбора:

Процедура ОбработкаПолученияДанныхВыбора(ДанныеВыбора, Параметры, СтандартнаяОбработка)
	
	СтандартнаяОбработка	= Ложь;

	Запрос			= ОбщегоНазначения.ПолучитьЗапросНаПоискПоЛексемамВСправочнике(Параметры.СтрокаПоиска,"Валюты");		
	//Запрос.Текст	= Запрос.Текст+" И НЕ Справочник.НеИспользоватьВВыборе";
	
	Результат				= Запрос.Выполнить();
	
	ДанныеВыбора			= Новый СписокЗначений;
	ВыборкаДетальныеЗаписи	= Результат.Выбрать();
	Пока ВыборкаДетальныеЗаписи.Следующий() Цикл
		
		Структура = Новый Структура("Значение,ПометкаУдаления",ВыборкаДетальныеЗаписи.Ссылка,ВыборкаДетальныеЗаписи.ПометкаУдаления);
		
		Элемент = ДанныеВыбора.Добавить();
		Элемент.Значение = Структура;
		
	КонецЦикла;
	
КонецПроцедуры

 

текст поиск вхождение слов

См. также

Поиск данных Внешние источники данных Системный администратор Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Если вам нужно автоматически генерировать представления (view) к вашей базе данных 1С (есть две версии - для СУБД MS SQL Server и для PostgreSQL) по структуре метаданных 1С, то вам необходима данная обработка. Наш "Генератор View", другими словами - это коннектор к данным 1С для Power BI - незаменимый помощник для бизнес-аналитиков, работающих с базами 1С из Yandex Datalens/Power BI и т.д. Работает для обычных и управляемых форм под 1С 8.3

230000 руб.

31.07.2020    13500    13    48    

25

Поиск данных Системный администратор Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Обработки помогут Вам легко и, главное, быстро (в 5 раз и быстрее штатной обработки 1С), выполнить поиск дублирующих данных в Ваших базах 1С на платформах 8.1-8.3. Это позволит уменьшить объем лишней информации в справочниках и документах, планах видов характеристик и др., упростит работу с данными пользователям. А так же можно, одним нажатием, узнать в каких ссылочных объектах есть вообще дубли! Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. А так же обновления Вы получаете бесплатно в течение года с момента приобретения данных обработок! (Обновление от 27.11.2023, версия 6.12)

10800 руб.

14.05.2012    158455    338    253    

570

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 1С:ERP Управление предприятием 2 Платные (руб)

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

2400 руб.

29.06.2020    18407    26    6    

40

Розничная торговля WEB-интеграция Поиск данных Пользователь Платформа 1С v8.3 Оперативный учет 1С:Розница 2 1С:Управление торговлей 11 Управленческий учет Платные (руб)

Альтернатива сервису 1С Номенклатура, не требует подписки ИТС, ищет данные в открытых источниках. Для поиска товара по штрихкоду в сети интернет, полезно для первоначального заполнения базы.

1999 руб.

15.10.2020    18882    23    63    

24

Инструментарий разработчика Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

2 стартмани

10.04.2023    11371    161    acces969    31    

122

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    5147    kalyaka    6    

33

Поиск данных Корректировка данных Программист Бухгалтер Пользователь Платформа 1С v8.3 Управляемые формы Платформа 1C v8.2 Конфигурации 1cv8 Платные (руб)

Обработка предназначена для гибкого поиска и дальнейшей замены дублей справочников, документов, а также планов видов расчетов и планов видов характеристик. В обработку включена возможность проверки наличия ссылки во внешней базе (по УИДу), поиска дублей с предварительным отбором, а также произвольной обработки реквизитов перед поиском (например, возможно удалить определенные символы из наименования).

3600 руб.

30.03.2022    8898    3    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. tormozit 7217 07.04.19 20:12 Сейчас в теме
Чем не устроил стандартный механизм?
Прикрепленные файлы:
4. user635629_exter 37 09.04.19 16:33 Сейчас в теме
(1) спасибо, не знал про это.
(3) спасибо, перед публикацией честно искал дубли, не нашел. По ссылке хорошая вещь, но мне бы по-проще.
2. RustIG 1727 07.04.19 20:30 Сейчас в теме
(0) интересный способ!
(1) то, что обратили внимание на типовой механизм +
а так-то можно и порассуждать:
а) типовой механизм - работает только для справочников, а в статье универсально механизм - можно применить алгоритм для поиска всех документов с комментарием "Иванов" + "наличка"
б) типовой механизм работает только для поля ввода, а в статье универсально - для любого элемента формы можно запустить поиск - например, обход строк в ТабличномДокументе и поиск чего-либо
в) неизвестно как запрограммирован типовой алгоритм, а тут код открыт - можно свою функциональность довнести.
3. Evg-Lylyk 4814 08.04.19 11:29 Сейчас в теме
Оставьте свое сообщение