Rasa 中文 FAQ 项目教程
2024-08-31 00:54:06作者:江焘钦
本文档基于开源项目 Dustyposa/rasa_ch_faq 编写,旨在提供项目的详细使用指南。以下内容将涵盖项目的目录结构、启动文件以及配置文件的介绍。
1. 项目的目录结构及介绍
项目的目录结构如下:
rasa_ch_faq/
├── data/
│ ├── nlu/
│ │ └── rasa_faq.yml
│ └── stories/
│ └── stories.yml
├── models/
├── actions/
│ └── actions.py
├── config.yml
├── domain.yml
├── endpoints.yml
└── requirements.txt
各目录和文件的介绍如下:
data/:包含训练数据。nlu/:包含自然语言理解(NLU)数据。rasa_faq.yml:NLU 训练数据文件。
stories/:包含对话流程(故事)数据。stories.yml:故事训练数据文件。
models/:存放训练好的模型文件。actions/:包含自定义动作的实现。actions.py:自定义动作的 Python 文件。
config.yml:项目的配置文件,包含 NLU 和核心配置。domain.yml:定义了对话机器人的领域,包括意图、实体、槽位、响应等。endpoints.yml:定义了外部服务的端点。requirements.txt:项目依赖的 Python 包列表。
2. 项目的启动文件介绍
项目的启动文件主要是 actions/actions.py 和 config.yml。
actions/actions.py
该文件包含了自定义动作的实现。例如:
from rasa_sdk import Action, Tracker
from rasa_sdk.executor import CollectingDispatcher
class ActionDefaultFallback(Action):
def name(self):
return "action_default_fallback"
def run(self, dispatcher: CollectingDispatcher, tracker: Tracker, domain: dict):
dispatcher.utter_message(text="对不起,我不明白你的意思。")
return []
config.yml
该文件包含了 NLU 和核心配置,例如:
language: "zh"
pipeline:
- name: "WhitespaceTokenizer"
- name: "RegexFeaturizer"
- name: "LexicalSyntacticFeaturizer"
- name: "CountVectorsFeaturizer"
- name: "CountVectorsFeaturizer"
analyzer: "char_wb"
min_ngram: 1
max_ngram: 4
- name: "DIETClassifier"
epochs: 100
- name: "EntitySynonymMapper"
- name: "ResponseSelector"
epochs: 100
policies:
- name: "MemoizationPolicy"
- name: " TEDPolicy"
max_history: 5
epochs: 100
- name: "FallbackPolicy"
nlu_threshold: 0.3
core_threshold: 0.3
ambiguity_threshold: 0.1
3. 项目的配置文件介绍
domain.yml
该文件定义了对话机器人的领域,包括意图、实体、槽位、响应等。例如:
intents:
- greet
- goodbye
- affirm
- deny
- mood_great
- mood_unhappy
entities:
- name
slots:
name:
type: text
responses:
utter_greet:
- text: "你好!有什么可以帮助你的吗?"
utter_goodbye:
- text: "再见!"
utter_happy:
- text: "太好了!"
utter_unhappy:
- text: "很抱歉听到你不开心。"
endpoints.yml
该文件定义了外部服务的端点,例如:
action_endpoint:
url: "http://localhost:5055/webhook"
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
Ascend Extension for PyTorch
Python
617
795
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
433
395
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
145
237
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.18 K
152
暂无简介
Dart
983
252
Oohos_react_native
React Native鸿蒙化仓库
C++
348
403
昇腾LLM分布式训练框架
Python
166
198
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.68 K
989