19、用 Python + OpenAI 构建一个命令行 AI 问答助手

🎯 教你用最少的代码,快速打造一个能在命令行对话的"ChatGPT 助手",支持多轮问答、聊天记录、持久化保存,既是工具也是项目展示。


✅ 本文目标

  • 通过 openai API 与 GPT 模型对话
  • 支持命令行输入 & 结构化输出
  • 加入历史上下文(记忆)
  • 可扩展成 CLI 工具或本地知识助手

🧰 环境准备

1. 安装依赖

复制代码
pip install openai rich

2. 获取 OpenAI API Key


🧠 基本结构(chat.py

python 复制代码
import openai
from rich import print
from rich.console import Console

# ✅ 替换成你的 OpenAI API 密钥
openai.api_key = "sk-xxxxx"

console = Console()
messages = [{"role": "system", "content": "你是一个有趣又专业的编程助手"}]

def chat():
    while True:
        try:
            user_input = console.input("[bold green]你:[/] ")
            if user_input.lower() in ["exit", "quit"]:
                break

            messages.append({"role": "user", "content": user_input})

            res = openai.ChatCompletion.create(
                model="gpt-3.5-turbo",  # 或 gpt-4
                messages=messages
            )

            reply = res.choices[0].message["content"]
            messages.append({"role": "assistant", "content": reply})
            console.print(f"[bold blue]助手:[/] {reply}\n")

        except Exception as e:
            print(f"[red]❌ 错误:{e}[/]")

if __name__ == "__main__":
    chat()

✨ 效果演示

ruby 复制代码
$ python chat.py
你:帮我写个快速排序
助手:
当然可以!这是 Python 版本的快速排序代码:
...

🧠 加分功能建议

功能 说明
保存对话记录 写入 chat_log.txt
使用 argparse 支持 --model gpt-4--prompt 等参数
本地嵌入文档 实现 Retrieval-Augmented Generation(进阶)
响应多行 markdown 使用 rich.markdown.Markdown 美化输出

📁 示例目录结构

bash 复制代码
chat-assistant/
├── chat.py
├── .env               # 可存放 API_KEY
└── README.md

✅ 项目实用价值

  • CLI 工具原型,能快速回答技术问题
  • 可扩展成"Chat with PDF"、Chatbot 网站
  • 可部署到终端、桌面、网页任意形态

📦 扩展挑战

  • ✅ 用 langchain + Chroma 本地知识库
  • ✅ 封装为 todoai CLI 工具(支持 chat / code / explain)
  • ✅ 用 Textual 打造 TUI UI(超好看)
相关推荐
我的xiaodoujiao14 分钟前
API 接口自动化测试详细图文教程学习系列15--项目实战演练2
python·学习·测试工具·pytest
多思考少编码1 小时前
PAT甲级真题1001 - 1005题详细题解(C++)(个人题解)
c++·python·最短路·pat·算法竞赛
ZhengEnCi1 小时前
M5-markconv自定义CSS样式指南 📝
前端·css·python
阿丰资源2 小时前
基于Spring Boot的电影城管理系统(直接运行)
java·spring boot·后端
IT_陈寒2 小时前
SpringBoot自动配置的坑差点让我加班到天亮
前端·人工智能·后端
ZhengEnCi2 小时前
M4-更新日志v0.1.3-Mermaid图表支持 📝
python
hsjcjh2 小时前
多模态长文本协同:用Gemini 3.1 Pro镜像官网破解复杂办公场景的效率困局(国内实测方案)
python
凯瑟琳.奥古斯特2 小时前
SQLAlchemy核心功能解析
开发语言·python·flask
卷Java2 小时前
GPTQ vs AWQ vs GGUF:模型量化工具横向测评
开发语言·windows·python
消失的旧时光-19433 小时前
Spring Boot 工程化进阶:统一返回 + 全局异常 + AOP 通用工具包
java·spring boot·后端·aop·自定义注解