名称: chart-image
版本: 2.5.1
描述: 从数据生成出版物质量的图表图像。支持折线图、柱状图、面积图、散点图、K线图、饼图/环形图、热力图、多系列图和堆叠图。适用于数据可视化、创建图表、绘制时间序列或为报告/告警生成图表图像。专为 Fly.io/VPS 部署设计——无需原生编译、无需 Puppeteer、无需浏览器。纯 Node.js,使用预构建的二进制文件。
provides:
- capability: chart-generation
methods: [lineChart, barChart, areaChart, pieChart, candlestickChart, heatmap]
使用 Vega-Lite 从数据生成 PNG 图表图像。非常适合无头服务器环境。
专为 Fly.io / VPS / Docker 部署打造:
- ✅ 无需原生编译 - 使用带有预构建二进制文件的 Sharp(与需要构建工具的 canvas 不同)
- ✅ 无需 Puppeteer/浏览器 - 纯 Node.js,无需下载 Chrome,无头浏览器开销
- ✅ 轻量级 - 总依赖约 15MB,而基于 Puppeteer 的解决方案超过 400MB
- ✅ 快速冷启动 - 无浏览器启动延迟,图表生成时间 <500ms
- ✅ 离线工作 - 无需外部 API 调用(与 QuickChart.io 不同)
cd /data/clawd/skills/chart-image/scripts && npm install
node /data/clawd/skills/chart-image/scripts/chart.mjs \
--type line \
--data '[{"x":"10:00","y":25},{"x":"10:30","y":27},{"x":"11:00","y":31}]' \
--title "价格随时间变化" \
--output chart.png
node chart.mjs --type line --data '[{"x":"A","y":10},{"x":"B","y":15}]' --output line.png
node chart.mjs --type bar --data '[{"x":"A","y":10},{"x":"B","y":15}]' --output bar.png
node chart.mjs --type area --data '[{"x":"A","y":10},{"x":"B","y":15}]' --output area.png
# 饼图
node chart.mjs --type pie --data '[{"category":"A","value":30},{"category":"B","value":70}]' \
--category-field category --y-field value --output pie.png
# 环形图(带中心孔)
node chart.mjs --type donut --data '[{"category":"A","value":30},{"category":"B","value":70}]' \
--category-field category --y-field value --output donut.png
node chart.mjs --type candlestick \
--data '[{"x":"Mon","open":100,"high":110,"low":95,"close":105}]' \
--open-field open --high-field high --low-field low --close-field close \
--title "股票价格" --output candle.png
node chart.mjs --type heatmap \
--data '[{"x":"Mon","y":"Week1","value":5},{"x":"Tue","y":"Week1","value":8}]' \
--color-value-field value --color-scheme viridis \
--title "活动热力图" --output heatmap.png
在一张图表上比较多个趋势:
node chart.mjs --type line --series-field "market" \
--data '[{"x":"Jan","y":10,"market":"A"},{"x":"Jan","y":15,"market":"B"}]' \
--title "对比" --output multi.png
node chart.mjs --type bar --stacked --color-field "category" \
--data '[{"x":"Mon","y":10,"category":"Work"},{"x":"Mon","y":5,"category":"Personal"}]' \
--title "按类别划分的小时数" --output stacked.png
价格折线叠加成交量柱状图:
node chart.mjs --type line --volume-field volume \
--data '[{"x":"10:00","y":100,"volume":5000},{"x":"11:00","y":105,"volume":3000}]' \
--title "价格 + 成交量" --output volume.png
node chart.mjs --sparkline --data '[{"x":"1","y":10},{"x":"2","y":15}]' --output spark.png
迷你图默认为 80x20 像素,透明背景,无坐标轴。
| 选项 | 描述 | 默认值 |
|---|---|---|
--type |
图表类型:line, bar, area, point, pie, donut, candlestick, heatmap | line |
--data |
数据点的 JSON 数组 | - |
--output |
输出文件路径 | chart.png |
--title |
图表标题 | - |
--width |
宽度(像素) | 600 |
--height |
高度(像素) | 300 |
| 选项 | 描述 | 默认值 |
|---|---|---|
--x-field |
X 轴字段名 | x |
--y-field |
Y 轴字段名 | y |
--x-title |
X 轴标签 | 字段名 |
--y-title |
Y 轴标签 | 字段名 |
--x-type |
X 轴类型:ordinal, temporal, quantitative | ordinal |
--y-domain |
Y 轴刻度范围,格式为 "最小值,最大值" | 自动 |
| 选项 | 描述 | 默认值 |
|---|---|---|
--color |
线条/柱状颜色 | #e63946 |
--dark |
深色模式主题 | false |
--svg |
输出 SVG 而非 PNG | false |
--color-scheme |
Vega 配色方案(category10, viridis 等) | - |
| 选项 | 描述 | 默认值 |
|---|---|---|
--show-change |
在最后一个数据点显示 +/-% 变化注释 | false |
--focus-change |
将 Y 轴缩放至 2 倍数据范围 | false |
--focus-recent N |
仅显示最后 N 个数据点 | 全部 |
--show-values |
标注最小/最大峰值点 | false |
| 选项 | 描述 | 默认值 |
|---|---|---|
--series-field |
多系列折线图的字段 | - |
--stacked |
启用堆叠柱状图模式 | false |
--color-field |
堆叠/颜色分类的字段 | - |
| 选项 | 描述 | 默认值 |
|---|---|---|
--open-field |
OHLC 开盘价字段 | open |
--high-field |
OHLC 最高价字段 | high |
--low-field |
OHLC 最低价字段 | low |
--close-field |
OHLC 收盘价字段 | close |
| 选项 | 描述 | 默认值 |
|---|---|---|
--category-field |
饼图扇区分类的字段 | x |
--donut |
渲染为环形图(带中心孔) | false |
| 选项 | 描述 | 默认值 |
|---|---|---|
--color-value-field |
热力图强度的字段 | value |
--y-category-field |
Y 轴分类字段 | y |
| 选项 | 描述 | 默认值 |
|---|---|---|
--y2-field |
第二个 Y 轴字段(独立的右侧轴) | - |
--y2-title |
第二个 Y 轴的标题 | 字段名 |
--y2-color |
第二个系列的颜色 | #60a5fa (深色) / #2563eb (浅色) |
--y2-type |
第二个轴的图表类型:line, bar, area | line |
示例: 收入柱状图(左)+ 流失率面积图(右):
node chart.mjs \
--data '[{"month":"Jan","revenue":12000,"churn":4.2},...]' \
--x-field month --y-field revenue --type bar \
--y2-field churn --y2-type area --y2-color "#60a5fa" \
--y-title "收入 ($)" --y2-title "流失率 (%)" \
--x-sort none --dark --title "收入 vs 流失率"
| 选项 | 描述 | 默认值 |
|---|---|---|
--volume-field |
成交量柱状图的字段(启用双轴) | - |
--volume-color |
成交量柱状图的颜色 | #4a5568 |
| 选项 | 描述 | 默认值 |
|---|---|---|
--y-format |
Y 轴格式:percent, dollar, compact, decimal4, integer, scientific,或 d3-format 字符串 | 自动 |
--subtitle |
图表标题下方的副标题文本 | - |
--hline |
水平参考线:格式为 "值" 或 "值,颜色" 或 "值,颜色,标签"(可重复) | - |
| 选项 | 描述 | 默认值 |
|---|---|---|
--annotation |
静态文本注释 | - |
--annotations |
事件标记的 JSON 数组 | - |
node chart.mjs --type line --data '[...]' \
--title "伊朗打击概率(48小时)" \
--show-change --focus-change --show-values --dark \
--output alert.png
仅显示近期活动:
node chart.mjs --type line --data '[hourly data...]' \
--focus-recent 4 --show-change --focus-change --dark \
--output recent.png
在图表上标记事件:
node chart.mjs --type line --data '[...]' \
--annotations '[{"x":"14:00","label":"新闻爆发"},{"x":"16:30","label":"新闻发布会"}]' \
--output annotated.png
用于处理日期间隔的正确时间序列:
node chart.mjs --type line --x-type temporal \
--data '[{"x":"2026-01-01","y":10},{"x":"2026-01-15","y":20}]' \
--output temporal.png
当 X 值为 ISO 日期且希望间距反映实际时间间隔(而非均匀间隔)时,使用 --x-type temporal。
格式化坐标轴值以提高可读性:
# 美元金额
node chart.mjs --data '[...]' --y-format dollar --output revenue.png
# → $1,234.56
# 百分比(值为 0-1 的小数)
node chart.mjs --data '[...]' --y-format percent --output rates.png
# → 45.2%
# 大数字紧凑格式
node chart.mjs --data '[...]' --y-format compact --output users.png
# → 1.2K, 3.4M
# 加密货币价格(4位小数)
node chart.mjs --data '[...]' --y-format decimal4 --output molt.png
# → 0.0004
# 自定义 d3-format 字符串
node chart.mjs --data '[...]' --y-format ',.3f' --output custom.png
可用快捷方式:percent, dollar/usd, compact, integer, decimal2, decimal4, scientific
在标题下方添加上下文:
node chart.mjs --title "MOLT 价格" --subtitle "持有 20,668 MOLT" --data '[...]' --output molt.png
使用 --dark 启用深色模式。根据时间自动选择:
- 夜间(当地时间 20:00-07:00):--dark
- 日间(当地时间 07:00-20:00):浅色模式(默认)
echo '[{"x":"A","y":1},{"x":"B","y":2}]' | node chart.mjs --output out.png
用于高级图表:
node chart.mjs --spec my-spec.json --output custom.png
生成图表后,务必将其发送回用户频道。
不要仅仅保存到文件并描述它——整个重点在于可视化。
# 1. 生成图表
node chart.mjs --type line --data '...' --output /data/clawd/tmp/my-chart.png
# 2. 发送它!使用 message 工具并指定 filePath:
# action=send, target=<channel_id>, filePath=/data/clawd/tmp/my-chart.png
提示:
- 保存到 /data/clawd/tmp/(持久化),而不是 /tmp/(可能被清理)
- 使用 action=send 并指定 filePath——thread-reply 不支持文件附件
- 在消息文本中包含简要说明
- 在以色列时间 20:00-07:00 之间自动使用 --dark
更新日期:2026-02-04 - 新增 --y-format (percent/dollar/compact/decimal4) 和 --subtitle