Реализация голосового AI-бота для call-центра
Голосовой бот для колл-центра обрабатывает входящие и исходящие звонки, снимая нагрузку с операторов на типовые запросы: проверку статуса заказа, изменение данных, ответы на FAQ. При Containment Rate >60% бот окупается за 4–8 месяцев.
Типовые сценарии и покрытие
| Сценарий | Доля звонков | Автоматизация |
|---|---|---|
| Статус заказа | 30–40% | 95% |
| Изменение адреса | 10–15% | 80% |
| FAQ по продукту | 15–20% | 85% |
| Жалобы | 5–10% | 30% (далее оператор) |
| Запись/отмена | 10–15% | 90% |
Архитектура бота для call-центра
from enum import Enum
from dataclasses import dataclass
class DialogState(Enum):
GREETING = "greeting"
INTENT_RECOGNITION = "intent_recognition"
COLLECTING_DATA = "collecting_data"
PROCESSING = "processing"
CONFIRMATION = "confirmation"
TRANSFER_TO_AGENT = "transfer_to_agent"
FAREWELL = "farewell"
@dataclass
class CallSession:
call_id: str
phone_number: str
state: DialogState = DialogState.GREETING
intent: str = None
collected: dict = None
retry_count: int = 0
max_retries: int = 3
def should_transfer(self) -> bool:
return (self.retry_count >= self.max_retries or
self.intent in ["complaint", "complex_issue"])
Intent recognition с примерами
async def recognize_intent(user_text: str) -> dict:
response = await client.chat.completions.create(
model="gpt-4o-mini",
messages=[{
"role": "system",
"content": """Определи намерение клиента. Верни JSON:
{"intent": "order_status|change_address|cancel_order|complaint|other",
"entities": {"order_id": "...", "address": "..."}}"""
}, {
"role": "user",
"content": user_text
}],
response_format={"type": "json_object"}
)
return json.loads(response.choices[0].message.content)
Условия эскалации на оператора
ESCALATION_TRIGGERS = [
"оператор", "живой человек", "соедините с человеком",
"не понимаете", "бесполезный", "жалоба", "претензия",
"верните деньги", "суд", "роспотребнадзор"
]
def should_escalate(text: str, session: CallSession) -> bool:
text_lower = text.lower()
if any(trigger in text_lower for trigger in ESCALATION_TRIGGERS):
return True
if session.retry_count >= 2:
return True
return False
Интеграция с CRM
async def lookup_customer(phone: str) -> dict | None:
# Запрос в CRM (Bitrix24, amoCRM, Salesforce)
async with aiohttp.ClientSession() as session:
resp = await session.get(
f"{CRM_API_URL}/contacts/search",
params={"phone": phone},
headers={"Authorization": f"Bearer {CRM_TOKEN}"}
)
data = await resp.json()
return data.get("contact")
Сроки: MVP с 3–5 сценариями — 4–6 недель. Полная система с аналитикой и A/B тестами — 3–4 месяца.







