ИП Горелов Максим Николаевич 8 (915) 093-74-75
Поиск по файлам через OpenAI ResponsesAPI
Доступно на тарифе:
Бизнес 2025
Профи 2025
Что такое функция?
Функции — внешние инструменты (фрагменты кода), к которым могут обращаться LLM модели для решения задач пользователей. Модель не исполняет функции, но самостоятельно принимает решение о том как, когда и с какими параметрами их следует вызвать. При принятии решения о вызове функции модель исходит из доступных знаний, данных текущего разговора и описания функции. После обращения к функции модель может обработать результат ее работы.
Что такое параметры?
Это входные данные, которые функция использует для выполнения своей задачи. Они позволяют сделать функцию гибкой и многоразовой, так как она может работать с разными данными без изменения своего кода. Например, функция для генерации изображений может принимать параметры query
(описание изображения) и resolution
(разрешение), чтобы создавать разные картинки по запросу. Параметры нужны, чтобы функция знала, что именно ей нужно обработать или какие условия учесть при выполнении действия.
Как научить ИИ агента использовать эти параметры в функции?
Чтобы объяснить ИИ, какой параметр нужно передать, вы должны включить в промпт бота четкие инструкции. Эти инструкции должны описывать:
Когда нужно вызвать функцию (условие или триггер).
Какую функцию вызвать (по названию или номеру).
Какие параметры и из какой информации в диалоге их брать.
Например, если у вас есть функция для отправки лида (№26), и она принимает параметры name
, phone
, email
, вы можете написать в промпте:
"Если клиент пришлет свой номер телефона, то сразу же вызови функцию №26 (отправка лида). В качестве phone
передай номер телефона клиента, в качестве name
используй имя, которое клиент указал в диалоге, а email
возьми, если клиент его предоставил."
ИИ будет анализировать диалог и, когда увидит соответствующее условие (например, клиент назвал свой номер телефона), он попытается извлечь нужные данные и передать их в указанную функцию.
Принцип работы:
1. Высылаете ссылки на файлы в форматах: .c, .cpp, .cs, .css, .doc, .docx, .go, .html, .java, .js, .json, .md, .pdf, .php, .pptx, .py, .rb, .sh, .tex, .ts, .txt
2. Функция отвечает вам и выдает ID векторного хранилица
3. Далее вы можете в любом другом боте использовать эту же функцию и передавать ей ID этого хранилища и она будет отвечать по загруженным файлам
Параметры, которые можно передать в функцию openai_responses_rag:
query - текст запроса для поиска. Указывает, что именно нужно найти в файлах.
files_url - список файлов через запятую. Поддерживаемые форматы файлов: .c, .cpp, .cs, .css, .doc, .docx, .go, .html, .java, .js, .json, .md, .pdf, .php, .pptx, .py, .rb, .sh, .tex, .ts, .txt. Указывает файлы, которые будут проанализированы.
ai_model - модель OpenAI для использования. Рекомендуемая модель: gpt-4o-mini. Указывает, какую модель использовать для анализа.
vector_store_id - ID векторного хранилища в OpenAI. Если он передается, то files_url не нужно передавать.
"Пожалуйста, проанализируй файлы: https://example.com/file1.pdf, https://example.com/file2.docx."
"Ищи информацию о лучших практиках программирования в векторном хранилище с ID 12345."
ИП Горелов Максим Николаевич ИНН 500104951533 ОГРН 309500106900065