网淘吧来吧,欢迎您!

返回首页 微信
微信
手机版
手机版

Chart Image技能使用说明

2026-03-27 新闻来源:网淘吧 围观:13
电脑广告
手机广告

图表图像生成器

使用 Vega-Lite 从数据生成 PNG 图表图像。非常适合无头服务器环境。

为何选择此技能?

专为 Fly.io / VPS / Docker 部署而构建:

  • 无需原生编译- 使用带有预构建二进制文件的 Sharp(不像canvas那样需要构建工具)
  • 无需 Puppeteer/浏览器- 纯 Node.js 实现,无需下载 Chrome,无无头浏览器开销
  • 轻量级- 总依赖约 15MB,而基于 Puppeteer 的解决方案超过 400MB
  • 快速冷启动- 无浏览器启动延迟,生成图表时间 <500 毫秒
  • 支持离线工作- 无需调用外部 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 "Price Over Time" \
  --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

饼图 / 环形图

# Pie
node chart.mjs --type pie --data '[{"category":"A","value":30},{"category":"B","value":70}]' \
  --category-field category --y-field value --output pie.png

# Donut (with hole)
node chart.mjs --type donut --data '[{"category":"A","value":30},{"category":"B","value":70}]' \
  --category-field category --y-field value --output donut.png

K线图 (OHLC)

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 "Stock Price" --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 "Activity Heatmap" --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 "Comparison" --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 "Hours by Category" --output stacked.png

成交量叠加图(双Y轴)

价格线与成交量柱:

node chart.mjs --type line --volume-field volume \
  --data '[{"x":"10:00","y":100,"volume":5000},{"x":"11:00","y":105,"volume":3000}]' \
  --title "Price + Volume" --output volume.png

迷你趋势图(迷你内联图表)

node chart.mjs --sparkline --data '[{"x":"1","y":10},{"x":"2","y":15}]' --output spark.png

迷你趋势图默认为80x20像素,透明背景,无坐标轴。

选项参考

基本选项

选项 描述 默认值
--type 图表类型:折线图、条形图、面积图、点图、饼图、环形图、K线图、热力图 折线图
--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轴类型:序数型、时间型、数值型 序数型
--x-format 时间型X轴标签格式(d3-time-format,例如%b %d、%H:%M) 自动
--x-sort X轴排序:升序、降序或无(保持输入顺序) 自动
--x-label-limit PX X轴标签在Vega截断前的最大像素宽度 自动
--y-label-limit PX Y轴标签在Vega截断前的最大像素宽度 自动
--y-domain Y轴刻度范围,格式为"最小值,最大值" 自动
--y-pad 添加垂直内边距,作为范围的一部分(例如,0.1= 10%) 0

视觉选项

选项 描述 默认值
--color 线条/条形颜色 #e63946
--dark 深色模式主题 false
--svg 输出SVG格式而非PNG格式 false
--no-points 在线形图中隐藏点标记 false
--line-width N 为线形图设置线条粗细(单位:像素) 2
--point-size N 设置线图/点图的标记点大小 60
--bar-radius N 为柱状图设置圆角半径(像素) 0
--color-scheme Vega配色方案(category10、viridis等) -

警报/监控选项

选项 描述 默认值
--show-change 在最后数据点显示+/-%变化标注 false
--focus-change 将Y轴缩放至数据范围的2倍 false
--focus-recent N 仅显示最近N个数据点 all
--show-values 标注最小/最大峰值点 false
--last-value 标记最终数据点值 false

多系列/堆叠选项

选项 描述 默认值
--series-field 多系列折线图字段 -
--stacked 启用堆叠柱状图模式 false
--color-field 堆叠/颜色分类字段 -

K线图选项

选项 描述 默认值
--open-field OHLC开盘价字段 open
--high-field OHLC最高价字段 high
--low-field OHLC 最低价字段 最低价
--close-field OHLC 收盘价字段 收盘价

饼图/环图选项

选项 描述 默认值
--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 第二个轴的图表类型:折线图、条形图、面积图 折线图
--y2-format 右侧轴格式:百分比、美元、紧凑型、整数、四位小数,或d3格式字符串 自动

示例:收入条形图(左侧) + 客户流失面积图(右侧):

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" --y2-format ".1f" \
  --y-title "Revenue ($)" --y2-title "Churn (%)" \
  --x-sort none --dark --title "Revenue vs Churn"

成交量叠加选项(蜡烛图)

选项 描述 默认
--volume-field 成交量柱状图字段(启用双轴) -
--volume-color 成交量柱状图颜色 #4a5568

格式化选项

选项 描述 默认值
--y-format Y轴格式:百分比、美元、紧凑型、四位小数、整数、科学计数法,或d3格式字符串 自动
--subtitle 图表标题下方的副标题文本 -
--hline 水平参考线:"数值" 或 "数值,颜色" 或 "数值,颜色,标签"(可重复) -

注释选项

选项 描述 默认值
--annotation 静态文本标注 -
--annotations 事件标记的JSON数组 -

警报式图表(推荐用于监控器)

node chart.mjs --type line --data '[...]' \
  --title "Iran Strike Odds (48h)" \
  --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":"News broke"},{"x":"16:30","label":"Press conf"}]' \
  --output annotated.png

时间型X轴

适用于具有日期间隔的规范时间序列:

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-type temporal当X值为ISO日期格式,且您希望间距反映实际时间间隔(而非等间距)时。

Y轴格式设置

格式化坐标轴数值以提升可读性:

# Dollar amounts
node chart.mjs --data '[...]' --y-format dollar --output revenue.png
# → $1,234.56

# Percentages (values as decimals 0-1)
node chart.mjs --data '[...]' --y-format percent --output rates.png
# → 45.2%

# Compact large numbers
node chart.mjs --data '[...]' --y-format compact --output users.png
# → 1.2K, 3.4M

# Crypto prices (4 decimal places)
node chart.mjs --data '[...]' --y-format decimal4 --output molt.png
# → 0.0004

# Custom d3-format string
node chart.mjs --data '[...]' --y-format ',.3f' --output custom.png

可用快捷方式:percent,dollar/usd,紧凑,整数,两位小数,四位小数,科学计数法

图表副标题

在标题下方添加说明:

node chart.mjs --title "MOLT Price" --subtitle "20,668 MOLT held" --data '[...]' --output molt.png

主题选择

使用--dark启用深色模式。基于时间自动选择:

  • 夜间(当地时间20:00-07:00):--dark
  • 日间(当地时间07:00-20:00):浅色模式(默认)

社交媒体尺寸预设

当图表用于特定平台时,使用--output-size参数:

# Bluesky / OG-style landscape post
node chart.mjs --type line --data '[...]' --output-size bluesky --output bluesky-chart.png

# Instagram / Threads portrait post
node chart.mjs --type line --data '[...]' --output-size portrait --output portrait-chart.png

可用预设包括推特discordslacklinkedinbluesky(bsky别名),youtubeinstagram竖版故事缩略图宽屏和方形。数据管道自定义 Vega-Lite 规范适用于高级图表:thumbnail,wide, andsquare.

Piping Data

echo '[{"x":"A","y":1},{"x":"B","y":2}]' | node chart.mjs --output out.png

Custom Vega-Lite Spec

For advanced charts:

node chart.mjs --spec my-spec.json --output custom.png

⚠️ 重要:务必发送图片!

生成图表后,始终将其发送回用户频道。 不要仅仅保存到文件然后描述它——关键在于视觉效果。

# 1. Generate the chart
node chart.mjs --type line --data '...' --output /data/clawd/tmp/my-chart.png

# 2. Send it! Use message tool with filePath:
#    action=send, target=<channel_id>, filePath=/data/clawd/tmp/my-chart.png

提示:

  • 保存到/data/clawd/tmp/(持久性目录),而非/tmp/(可能被清理)
  • 使用action=send配合filePath参数注意:thread-reply
  • 不支持文件附件
  • 在消息文本中包含简要说明自动使用--dark

模式(以色列时间 20:00-07:00 期间)更新于:2026-03-20 - 已添加因此,双轴和成交量叠加图表可以独立格式化右轴(百分比、美元、紧凑型、自定义 d3 格式);版本已升级至 2.6.17。

天猫隐藏优惠券

网淘吧

免责申明
部分文章来自各大搜索引擎,如有侵权,请与我联系删除。
打赏
文章底部电脑广告
手机广告位-内容正文底部

相关文章

您是本站第291011名访客 今日有257篇新文章/评论