将数据可视化为图表。当用户需要生成柱状图、折线图、饼图、散点图、雷达图、桑基图、思维导图、流程图等图表时调用此技能,通过 curl 工具调用 AntV API 生成图表图片
---
name: chart-visualization
description: 将数据可视化为图表。当用户需要生成柱状图、折线图、饼图、散点图、雷达图、桑基图、思维导图、流程图等图表时调用此技能,通过 curl 工具调用 AntV API 生成图表图片
---
请根据用户输入的内容,将数据可视化为图表。
## 步骤
1. 分析用户数据和需求,选择最合适的图表类型
2. 构造符合规范的 JSON 请求体
3. 使用 curl 工具调用 API 生成图表图片
4. 将返回的图片 URL 以 Markdown 图片格式输出
## 图表选择指南
根据用户的数据特征和需求,选择最合适的图表类型:
- **时间序列**:用 `line`(趋势)或 `area`(累计趋势);两个不同量纲用 `dual-axes`
- **比较类**:用 `bar`(横向分类对比)或 `column`(纵向分类对比);频率分布用 `histogram`
- **占比类**:用 `pie`(比例构成)或 `treemap`(层级占比)
- **关系与流程**:用 `scatter`(相关性)、`sankey`(流向)或 `venn`(集合重叠)
- **层级与树形**:用 `organization-chart` 或 `mind-map`
- **专用类型**:
- `radar`:多维度对比
- `funnel`:流程阶段转化
- `liquid`:百分比/进度
- `word-cloud`:文本词频
- `boxplot` / `violin`:统计分布
- `network-graph`:复杂节点关系
- `fishbone-diagram`:因果分析
- `flow-diagram`:流程图
- `spreadsheet`:结构化数据表或透视表
## API 接口
POST https://antv-studio.alipay.com/api/gpt-vis
请求体为 JSON,必须包含 `type` 和 `source: "chart-visualization-skills"` 字段。
示例:
```bash
curl -X POST https://antv-studio.alipay.com/api/gpt-vis \
-H "Content-Type: application/json" \
-d '{"type":"line","source":"chart-visualization-skills","data":[{"time":"2025-01","value":100}],"title":"示例图表"}'
```
返回示例:
```json
{"success":true,"resultObj":"https://..."}
```
将 `resultObj` 中的 URL 以 Markdown 图片格式输出:``
## 支持的图表类型
| 分类 | 图表类型 |
|------|---------|
| 比较类 | 条形图(bar)、柱状图(column)、瀑布图(waterfall)、双轴图(dual-axes) |
| 趋势类 | 面积图(area)、折线图(line)、散点图(scatter) |
| 分布类 | 箱线图(boxplot)、直方图(histogram)、小提琴图(violin)、漏斗图(funnel) |
| 占比类 | 饼图(pie)、水波图(liquid)、词云(word-cloud) |
| 层级类 | 组织架构图(organization-chart)、思维导图(mind-map)、矩形树图(treemap)、桑基图(sankey) |
| 关系类 | 关系图(network-graph)、韦恩图(venn) |
| 流程类 | 流程图(flow-diagram)、鱼骨图(fishbone-diagram) |
| 多维类 | 雷达图(radar) |
| 表格类 | 表格/透视表(spreadsheet) |
## 通用可选参数
| 参数 | 类型 | 默认值 | 说明 |
|------|------|--------|------|
| theme | string | "default" | 主题:"default" / "academy" / "dark" |
| width | number | 600 | 图表宽度 |
| height | number | 400 | 图表高度 |
| title | string | "" | 图表标题 |
| style.texture | string | "default" | 纹理:"default" / "rough"(手绘风格) |
带坐标轴的图表还支持:axisXTitle、axisYTitle。
## 各图表 data 格式
- **area / line**: `{time: string, value: number, group?: string}[]`,可选 stack: boolean
- **bar**: `{category: string, value: number, group?: string}[]`,可选 group / stack (默认 stack: true)
- **column**: `{category: string, value: number, group?: string}[]`,可选 group (默认 true) / stack
- **scatter**: `{x: number, y: number, group?: string}[]`
- **pie**: `{category: string, value: number}[]`,可选 innerRadius: number (0-1)
- **radar**: `{name: string, value: number, group?: string}[]`
- **funnel**: `{category: string, value: number}[]`
- **waterfall**: `{category: string, value?: number, isTotal?: boolean, isIntermediateTotal?: boolean}[]`
- **dual-axes**: categories: string[], series: {type: "column"|"line", data: number[], axisYTitle?: string}[]
- **histogram**: `number[]`,可选 binNumber: number
- **boxplot / violin**: `{category: string, value: number, group?: string}[]`
- **liquid**: percent: number (0-1),可选 shape: "circle"|"rect"|"pin"|"triangle"
- **word-cloud**: `{text: string, value: number}[]`
- **sankey**: `{source: string, target: string, value: number}[]`,可选 nodeAlign
- **treemap**: `{name: string, value: number, children?: ...}[]` (最深 3 层)
- **venn**: `{sets: string[], value: number, label?: string}[]`
- **network-graph / flow-diagram**: `{nodes: {name: string}[], edges: {source: string, target: string, name?: string}[]}`
- **fishbone-diagram / mind-map**: `{name: string, children?: ...}` (最深 3 层)
- **organization-chart**: `{name: string, description?: string, children?: ...}` (最深 3 层),可选 orient: "horizontal"|"vertical"
- **spreadsheet**: `Record<string, string | number>[]`,可选 rows / columns / values(透视表字段)
Creator's repository · antvis/chart-visualization-skills