Skip to main content

Toolkit for Chat API

Project description

以 CLI 为核心的 Python 开发套件,集成 LLM 对话、工具箱(DNS、飞书、绘图等)、MCP 服务和环境管理。

安装

pip install chattool --upgrade
pip install "chattool[images]"   # 含图像工具
pip install "chattool[pypi]"     # 含 Python 包构建/发布依赖
pip install "chattool[dev]"      # 含 MCP 等开发依赖

功能概览

环境变量管理 (chatenv)

chatenv init -i                  # 交互式初始化(敏感字段自动隐藏)
chatenv init -i -t openai        # 仅初始化指定服务
chatenv cat                      # 查看配置(敏感值打码)
chatenv set OPENAI_API_KEY=sk-xxx
chatenv save work && chatenv use work   # 多 profile 管理

LLM 对话 (chattool.Chat)

from chattool import Chat

# 多轮对话
chat = Chat("Hello!")
chat.get_response()
chat.user("How are you?").get_response()

# 异步并发
import asyncio
base = Chat().system("你是助手")
tasks = [base.copy().user(f"主题 {i}").async_get_response() for i in range(5)]
responses = asyncio.run(asyncio.gather(*tasks))

# 流式输出
async for chunk in Chat().user("写一首诗").async_get_response_stream():
    if chunk.delta_content:
        print(chunk.delta_content, end="", flush=True)

飞书机器人 (chattool lark)

chattool lark send USER_ID "Hello"
chattool lark send USER_ID --image photo.png
chattool serve lark echo                        # 回显机器人
chattool serve lark ai --system "你是工作助手"  # AI 对话机器人
from chattool.tools.lark import LarkBot, ChatSession

bot = LarkBot()
session = ChatSession(system="你是助手")

@bot.on_message
def chat(ctx):
    ctx.reply(session.chat(ctx.sender_id, ctx.text))

bot.start()

DNS 管理 (chattool dns)

chattool dns get home.example.com
chattool dns set home.example.com -v 1.2.3.4
chattool dns ddns home.example.com --monitor
chattool dns cert-update -d example.com -e admin@example.com

AI 绘图 (chattool image)

chattool image pollinations generate "a cat in space" -o cat.png
chattool image siliconflow generate "a cute dog" -o dog.png

数据探索 (chattool explore)

chattool explore arxiv search -p ai4math -n 10
chattool explore arxiv daily -p math-formalization --days 3
chattool explore arxiv daily -p math-formalization-weekly --days 7 -v
chattool explore arxiv get 1706.03762 -v

其他工具

工具 命令 说明
网络扫描 chattool network 扫描局域网主机和端口
PyPI 工具 chattool pypi 创建、检查、构建、校验与发布 Python 包
MCP 服务 chattool mcp start 标准 MCP Server,供 Claude/Cursor 调用
环境安装 chattool setup codex/claude 安装 Codex / Claude Code 并写入配置
Skills chattool skill install 安装 ChatTool skills 到 Codex / Claude Code
CC-Connect chattool cc cc-connect 快速配置与启动

文档

完整文档见 chattool.wzhecnu.cn 仓库结构设计草案见 docs/design/python-library-repo-structure.md PyPI 发布命令设计草案见 docs/design/chattool-pypi-cli-design.md

快速建包可直接运行:

chattool pypi init -i

开源协议

MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

chattool-6.2.0.tar.gz (185.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

chattool-6.2.0-py3-none-any.whl (228.6 kB view details)

Uploaded Python 3

File details

Details for the file chattool-6.2.0.tar.gz.

File metadata

  • Download URL: chattool-6.2.0.tar.gz
  • Upload date:
  • Size: 185.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for chattool-6.2.0.tar.gz
Algorithm Hash digest
SHA256 2c5a755ef64e3765f1bbeb453fa646a3506955f5ad5d8bbf13f66fb38f23ab4f
MD5 54b1cd124a193b0f5896c4d8a5cf7a09
BLAKE2b-256 ef204cc77649648b880a648f9aa931d9eaab3a46c931084bd737218b6fe1f352

See more details on using hashes here.

File details

Details for the file chattool-6.2.0-py3-none-any.whl.

File metadata

  • Download URL: chattool-6.2.0-py3-none-any.whl
  • Upload date:
  • Size: 228.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for chattool-6.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 faf5e79aa582d877477eccdd16c098358e9c8aa900502e9756901629a2b42cf4
MD5 317c75058ae4a9d9440d3c34172e4530
BLAKE2b-256 f15d649948e08f0029d570ac1d81931f0c82652f576f92d0f223f687530d8ddd

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page