Реализация бота-ассистента для FAQ в мобильном приложении

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.
Разработка и поддержка любых видов мобильных приложений:
Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

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

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Реализация бота-ассистента для FAQ в мобильном приложении
Простая
~2-3 рабочих дня
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    756
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    624
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1054
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    862
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Реализация бота-ассистента для FAQ в мобильном приложении

FAQ-бот — самая недооцениваемая задача. Кажется простой, реализуется за день, но в продакшне неизбежно оказывается, что вопросы пользователей не совпадают с формулировками в базе. «Как вернуть товар?» и «возврат денег» — это один вопрос, но без семантического поиска система их не свяжет.

Семантический поиск против точного совпадения

Простой вариант: пользователь пишет ключевые слова, система ищет по базе через LIKE или Elasticsearch. Работает, когда пользователь знает правильные термины.

Для натуральных вопросов нужен embedding-поиск. Каждый вопрос из FAQ и каждый запрос пользователя превращается в вектор, ищем ближайшего соседа по косинусному расстоянию.

from openai import OpenAI
import numpy as np

client = OpenAI()

def embed(text: str) -> list[float]:
    response = client.embeddings.create(
        model="text-embedding-3-small",
        input=text
    )
    return response.data[0].embedding

def find_best_faq(query: str, faq_embeddings: dict) -> tuple[str, float]:
    query_vec = np.array(embed(query))
    best_score = -1
    best_key = None
    for key, vec in faq_embeddings.items():
        score = np.dot(query_vec, np.array(vec)) / (
            np.linalg.norm(query_vec) * np.linalg.norm(np.array(vec))
        )
        if score > best_score:
            best_score = score
            best_key = key
    return best_key, best_score

Порог score < 0.75 — отвечаем «не нашёл подходящего ответа, уточните вопрос». Без порога бот будет выдавать нерелевантные ответы с убедительным видом.

Структура базы FAQ

Каждая запись: вопрос (или несколько формулировок), ответ, категория, теги. Несколько формулировок одного вопроса улучшают recall при поиске.

Embeddings для FAQ вычисляются один раз при загрузке и кэшируются в Redis. При обновлении базы — инвалидируем кэш и пересчитываем.

Мобильный UI

Для FAQ-бота эффективна комбинация: категории-кнопки при старте диалога + свободный ввод.

Пользователь открывает чат → видит 4–6 категорий («Доставка», «Оплата», «Возврат», «Аккаунт») → тапает нужную → бот предлагает топ-3 вопроса в категории в виде чипов. Если ни один не подходит — пишет своими словами.

Такой UX снижает нагрузку на NLP и даёт пользователю структуру. Большинство находит ответ за 2–3 тапа, не вводя ни слова.

Кнопка «Это помогло?» под каждым ответом — обязательна. Негативные оценки формируют список вопросов для доработки базы.

Процесс работы

Формирование базы FAQ: сбор реальных вопросов из предыдущих обращений, категоризация.

Настройка embedding-поиска, подбор порога релевантности.

Мобильный UI с категориями и свободным вводом.

Аналитика: какие вопросы остаются без ответа — это входные данные для расширения базы.

Ориентиры по срокам

FAQ-бот с семантическим поиском на готовой базе — 2–4 дня. С разработкой структуры базы, категоризацией и аналитикой — до 1 недели.