name: hithink-industry-query description: 查询行业估值、财务、盈利、行情、板块排名等数据,支持自然语言问句输入,返回相关行业数据结果。当用户询问行业数据、行业估值、行业排名、行业财务、行业盈利、行业行情、板块排名等行业相关问题时,必须使用此技能。 license: Complete terms in LICENSE.txt
问财行业数据 使用指南
版本
1.0.0(与 X-Claw-Skill-Version 保持一致)
技能概述
本技能提供行业数据查询能力,支持:
- 行业估值数据查询
- 行业财务指标查询
- 行业盈利数据查询
- 行业行情数据查询
- 板块排名数据查询
- 支持自然语言问句输入,返回相关行业数据结果
数据来源:同花顺问财(https://www.iwencai.com/unifiedwap/chat)
使用前
首次使用 - 获取 API Key 所有技能都需要 IWENCAI_API_KEY 环境变量才能使用。 如果用户尚未配置,按以下步骤引导:
步骤 1:获取 API Key 在浏览器内打开同花顺i问财SkillHub页面:https://www.iwencai.com/skillhub
步骤 2:登录
步骤 3:点击具体的Skill,打开弹窗查看详情,在安装方式-Agent用户-找到您的IWENCAI_API_KEY这一段,复制
步骤 4:配置环境变量 获取到 API Key 后,直接复制指引文字发送给AI助手,或手动设置环境变量:
跨平台环境变量设置
macOS / Linux (bash / zsh):
export IWENCAI_API_KEY="your-api-key"
Windows (PowerShell):
$env:IWENCAI_API_KEY="your-api-key"
Windows (CMD):
set IWENCAI_API_KEY=your-api-key
核心处理流程
步骤 1: 接收用户 Query
接收用户的自然语言查询请求,分析用户意图,识别行业数据相关查询类型:
- 行业估值/财务查询
- 行业盈利/行情查询
- 板块排名查询
步骤 2: Query 改写
将用户问句适当改写为标准的金融查询问句,保持原意不变:
改写规则:
- 保留用户核心意图(如:行业估值、行业排名、行业盈利等)
- 将口语化表达转为标准金融术语
- 适当简化过于复杂的复合条件
- 改写后需保持原意不变
常用查询改写示例:
| 用户原始问句 | 改写后查询 |
|---|---|
| A股行业估值排名 | A股行业估值排名 |
| 银行业盈利如何 | 银行业盈利数据 |
| 新能源板块今天怎么样 | 新能源板块行情 |
| 哪个行业涨得最好 | 行业涨跌幅排名 |
步骤 3: API 调用
调用问财 OpenAPI 网关获取数据,使用 scripts/cli.py CLI 或直接在 skill 逻辑中构造 HTTP 请求。所有发往网关的请求必须严格携带以下 Header:
| Header | 取值说明 |
|---|---|
Authorization |
Bearer <API Key>,API Key 仅从环境变量 IWENCAI_API_KEY 读取 |
Content-Type |
application/json |
X-Claw-Call-Type |
normal(正常请求)或 retry(失败后的重试) |
X-Claw-Skill-Id |
hithink-industry-query(与 skill name 一致) |
X-Claw-Skill-Version |
1.0.0(与本文档版本一致) |
X-Claw-Plugin-Id |
none |
X-Claw-Plugin-Version |
none |
X-Claw-Trace-Id |
每次请求必须新生成的 64 字符全局唯一追踪 ID(推荐 secrets.token_hex(32)) |
请求体示例:
{
"query": "改写后的查询语句",
"page": "1",
"limit": "10",
"is_cache": "1",
"expand_index": "true"
}
Python 调用示例(含 Claw Headers):
import os
import json
import secrets
import urllib.request
url = "https://openapi.iwencai.com/v1/query2data"
api_key = os.environ["IWENCAI_API_KEY"]
trace_id = secrets.token_hex(32) # 64 字符唯一 ID
payload = {
"query": "A股行业估值排名",
"page": "1",
"limit": "10",
"is_cache": "1",
"expand_index": "true"
}
headers = {
"Authorization": f"Bearer {api_key}",
"Content-Type": "application/json",
"X-Claw-Call-Type": "normal",
"X-Claw-Skill-Id": "hithink-industry-query",
"X-Claw-Skill-Version": "1.0.0",
"X-Claw-Plugin-Id": "none",
"X-Claw-Plugin-Version": "none",
"X-Claw-Trace-Id": trace_id,
}
data = json.dumps(payload).encode("utf-8")
request = urllib.request.Request(url, data=data, headers=headers, method="POST")
response = urllib.request.urlopen(request, timeout=30)
result = json.loads(response.read().decode("utf-8"))
# 解析返回数据
datas = result.get("datas", []) # 当前页数据列表
code_count = result.get("code_count", 0) # 符合条件的总记录数
chunks_info = result.get("chunks_info", {}) # 查询字句信息
# 分页提示:如果 code_count > len(datas),通过增加 page 参数翻页
注意: 默认返回 10 条数据,但符合条件的总数可能更多,需关注 code_count 字段并通过分页获取全部数据。
步骤 4: 空数据处理
如果 datas 为空或无数据,适当放宽或简化查询条件后重新请求(最多尝试 2 次):
- 首次重试:去掉过于苛刻的条件,保留核心查询条件
- 二次重试:进一步放宽条件或使用更通用的表述
每次重试都算作一次改写,最终返回时需说明最终使用的查询问句。
步骤 5: 数据解析
解析返回的 datas 数组,提取相关指标:
for item in datas:
industry_name = item.get("行业名称") # 如 "银行"
# 其他字段根据查询类型而定,如行业估值、涨跌幅、行业净利润等
步骤 6: 数据扩展决策
skill 需要自行决策当前数据是否足够回答用户问题:
- 如果数据完整:直接返回格式化后的结果且保证表格数据正确解析为表格展示
- 如果需要更多背景信息:可以调用其他金融工具或者搜索工具获取相关资讯
步骤 7: 回答用户
组织语言回答用户问题,确保:
- 结果清晰易懂
- 如果改写了问句,需特别说明最终使用的查询问句
- 必须强调数据来源于同花顺问财
请求参数
| 参数名 | 类型 | 必填 | 说明 |
|---|---|---|---|
| query | STRING | 是 | 用户问句 |
| page | STRING | 否 | 分页参数,默认值:1 |
| limit | STRING | 否 | 分页参数,默认值:10 |
| is_cache | STRING | 否 | 缓存参数,默认值:1 |
| expand_index | STRING | 否 | 是否展开指数,默认值:true |
响应参数
| 参数名 | 类型 | 说明 |
|---|---|---|
| datas | ARRAY | 金融数据列表,对象数组,每个对象包含行业名称、行业估值、涨跌幅等字段 |
| code_count | INT | 符合查询条件的总记录数量(注意:可能大于当前返回的 datas 条数) |
| chunks_info | OBJECT | 用户问句查询返回的字句信息,包含查询条件的解析结果 |
响应示例:
{
"datas": [
{"行业名称": "银行", "行业估值": "5.23PE", "涨跌幅": "1.25%"}
],
"code_count": 31,
"chunks_info": {
"query": "A股行业估值排名",
"parsed_conditions": ["A股", "行业估值排名"]
}
}
重要提示:
datas默认只返回 10 条数据(可通过limit参数调整)code_count表示符合条件的总记录数,可能远大于datas的长度- 当
code_count > len(datas)时,需要通过page参数翻页获取更多数据 - 返回的表格数据需要解析
datas数组中的对象字段
CLI 使用方式
本 skill 提供跨平台 CLI 脚本 scripts/cli.py,基于 Python 3 标准库实现,无第三方依赖。
命令行参数
| 参数 | 类型 | 必填 | 说明 |
|---|---|---|---|
--query |
STRING | 是 | 直接传入查询字符串 |
--page |
STRING | 否 | 分页参数,值必须为正整数,默认值:1 |
--limit |
STRING | 否 | 每页条数,值必须为正整数,默认值:10 |
--api-key |
STRING | 否 | API 密钥(默认从环境变量读取) |
--call-type |
STRING | 否 | 调用类型:normal(正常请求)或 retry(重试请求),默认值:normal |
--timeout |
INT | 否 | 请求超时时间(秒),默认值:30 |
使用示例
# 查询A股行业估值排名
python3 scripts/cli.py --query "A股行业估值排名"
# 查询银行业盈利数据
python3 scripts/cli.py --query "银行业盈利数据"
# 查询新能源板块行情
python3 scripts/cli.py --query "新能源板块行情"
# 翻页查询
python3 scripts/cli.py --query "行业估值" --page 2 --limit 20
# 重试请求(放宽条件后使用 retry 标记)
python3 scripts/cli.py --query "A股行业估值排名" --call-type "retry"
# 指定超时时间(复杂查询可适当增加)
python3 scripts/cli.py --query "A股行业估值排名" --timeout 60
curl 示例(脱敏)
curl -X POST "https://openapi.iwencai.com/v1/query2data" \
-H "Authorization: Bearer $IWENCAI_API_KEY" \
-H "Content-Type: application/json" \
-H "X-Claw-Call-Type: normal" \
-H "X-Claw-Skill-Id: hithink-industry-query" \
-H "X-Claw-Skill-Version: 1.0.0" \
-H "X-Claw-Plugin-Id: none" \
-H "X-Claw-Plugin-Version: none" \
-H "X-Claw-Trace-Id: $(openssl rand -hex 32)" \
-d '{
"query": "A股行业估值排名",
"page": "1",
"limit": "10",
"is_cache": "1",
"expand_index": "true"
}'
Windows (PowerShell) 等价示例:
$bytes = New-Object byte[] 32; [System.Security.Cryptography.RandomNumberGenerator]::Create().GetBytes($bytes); $traceId = -join ($bytes | ForEach-Object { $_.ToString("x2") })
Invoke-RestMethod -Uri "https://openapi.iwencai.com/v1/query2data" -Method POST -Headers @{
"Authorization" = "Bearer $env:IWENCAI_API_KEY"
"Content-Type" = "application/json"
"X-Claw-Call-Type" = "normal"
"X-Claw-Skill-Id" = "hithink-industry-query"
"X-Claw-Skill-Version" = "1.0.0"
"X-Claw-Plugin-Id" = "none"
"X-Claw-Plugin-Version" = "none"
"X-Claw-Trace-Id" = $traceId
} -Body '{"query":"A股行业估值排名","page":"1","limit":"10","is_cache":"1","expand_index":"true"}'
数据来源标注
重要提示:
- 引用同花顺数据时,必须强调数据来源于同花顺问财(https://www.iwencai.com/unifiedwap/chat)
- 如果没有查询到数据,提示用户可以到同花顺问财 web端查询(https://www.iwencai.com/unifiedwap/chat)
错误处理
密钥缺失(环境变量未设置且未传
--api-key): 代理必须口头提示用户「使用前」中的完整 API Key 获取指引文案,即:首次使用 - 获取 API Key 所有技能都需要 IWENCAI_API_KEY 环境变量才能使用。 如果用户尚未配置,按以下步骤引导:
步骤 1:获取 API Key 在浏览器内打开同花顺i问财SkillHub页面:https://www.iwencai.com/skillhub
步骤 2:登录
步骤 3:点击具体的Skill,打开弹窗查看详情,在安装方式-Agent用户-找到您的IWENCAI_API_KEY这一段,复制
步骤 4:配置环境变量 获取到 API Key 后,直接复制指引文字发送给AI助手,或手动设置环境变量:
无数据返回:引导用户访问同花顺问财(https://www.iwencai.com/unifiedwap/chat)。
最多重试 2 次逐步放宽条件(重试时
X-Claw-Call-Type改为retry)。
代码结构
hithink-industry-query/
├── SKILL.md # Skill 配置文件
├── LICENSE.txt # 许可证文件
└── scripts/
└── cli.py # CLI 入口(单一脚本,内含 API 调用和数据处理)