Install
openclaw skills install wjx-mcp-useGuide for using wjx-mcp-server MCP tools to interact with the Wenjuanxing (问卷星) platform. Use when the user mentions: 问卷, 调查, 收集, 表单, 投票, 考试, 测评, 满意度, NPS, 问卷星, wjx, survey, questionnaire — or wants to create surveys, query responses, analyze data, manage contacts, or generate SSO links via MCP protocol. Covers 58 tools, 8 resources, and 22 prompts.
openclaw skills install wjx-mcp-usewjx-mcp-server 提供 58 个 MCP 工具、8 个参考资源和 23 个 prompt 模板,覆盖问卷星 OpenAPI 的全部能力。
create_survey_by_json(强制)禁止使用 create_survey_by_text 与 create_survey——除非用户用"DSL"、"文本格式"、"老版接口"等字眼明确要求。原因:DSL 只覆盖 27 种题型而 JSON 覆盖 70+,且 DSL 容易被字符转义破坏。所有题型、投票、考试、表单都走 create_survey_by_json。
无论用户要求多少种题型,必须在一次 create_survey_by_json 调用中包含所有题目。一个问卷可包含任意数量、任意类型的题目。
"投票/考试/调查"是问卷类型(atype 参数)。JSONL 创建投票时使用 qtype:"投票单选" / qtype:"投票多选",并显式传 atype: 3;只有旧 DSL 文本格式才使用普通 [单选题] / [多选题],不存在 [投票单选题] 标签。
签名题(用 [绘图题] 替代)、地区题(用 [多级下拉题] 或网页端添加)、NPS 专用题(用 [量表题] + 0~10)不在 DSL 支持范围内。告知用户替代方案,继续创建其他题目,不要反复尝试或拆分多个问卷。
用户不需要知道 MCP 工具的存在。不要在回复中展示工具名或调用参数。唯一例外:用户明确要求调试时。
在首次配置/初始化、用户明确要求检查配置,或工具实际返回 API Key 相关错误时,引导用户处理 API Key。
WJX_API_KEY 环境变量API Key is required、Invalid API Key、appkey error 或类似鉴权错误,必须立刻向用户说明需要处理 API Key,并给出获取/更新 WJX_API_KEY 的下一步;不要只复述错误信息,也不要继续调用其他业务工具反复尝试WJX_BASE_URL 环境变量(如 https://xxx.sojump.cn)https://<域名>/weixinlogin.aspx?redirecturl=%2Fnewwjx%2Fmanage%2Fuserinfo.aspx%3FshowApiKey%3D1,微信扫码登录后复制 Keynpm install -g wjx-cli 后用 wjx init --api-key <key> 统一配置收到 API Key 相关错误后的用户提醒应使用自然语言,不暴露 MCP 工具调用细节,例如:
刚才的操作返回了 API Key 相关错误,所以我暂时不能继续创建或查询问卷。请先打开下面的链接获取/重新获取 API Key,然后在 MCP 配置中添加或更新 WJX_API_KEY 环境变量:
https://www.wjx.cn/weixinlogin.aspx?redirecturl=%2Fnewwjx%2Fmanage%2Fuserinfo.aspx%3FshowApiKey%3D1
submit_response 内部会自动 get_survey 取最新 version 并注入。不要手动算或省略。仅当外部已自行管理版本时才显式传入 jpmversion 参数。问卷被发布/编辑后服务端 version 自增,不带最新版本号会被拒绝并报"问卷已被修改请刷新"。get_survey 返回的原始 q_index:服务端严格按此校验——"问卷基础信息"元数据占 q_index=1,真实题目从 2 开始。AI 自己按"第 N 题"顺序数(1$..., 2$...)极易与服务端 q_index 错位,被拒"5〒答案不符合要求"。正确流程:先 get_survey({ vid, get_questions: true }) 拿 questions[].q_index,再按每题 q_index 拼 submitdata。选项序号仍是 1-based(从 1 数到 N)。, 分隔(每题 3 条可复制示例):
3$1!1,2!3,3!2 — 第 3 题第 1 行选第 1 列、第 2 行选第 3 列、第 3 行选第 2 列4$1!1|2,2!3,3!1|4 — 同一行多个列用 | 拼5$1!5,2!4,3!3 — 行号!分值get_survey 返回的 item_rows.length;items 数组是列头(列选项),不是行。submit_response 仅用于答题端提交。| 用户意图 | 工具 |
|---|---|
| 做调查/问卷 | create_survey_by_json(支持 70+ 题型) |
| 做考试/测验 | create_survey_by_json + prompt generate-exam-json,atype: 6 |
| 做投票 | create_survey_by_json + atype: 3 |
| 做表单/报名表 | create_survey_by_json + prompt generate-form-json,atype: 7 |
| 看问卷结果 | get_report({ vid }) 统计概览,query_responses({ vid }) 明细 |
| 导出答卷数据 | download_responses({ vid }) |
| 查看问卷链接 | build_survey_url({ mode: "edit", activity: vid }) |
| 分析 NPS | calculate_nps({ scores: [...] }) |
| 查当前配置 | get_config({}) |
| 模块 | 工具数 | 说明 |
|---|---|---|
| 问卷管理 | 13 | create_survey_by_json(推荐), create_survey, create_survey_by_text(已弃用), get_survey, list_surveys, update_survey_status, get/update_survey_settings, delete_survey, get_question_tags, get_tag_details, upload_file, clear_recycle_bin |
| 答卷数据 | 9 | query_responses, query_responses_realtime, download_responses, get_report, submit_response, get_winners, modify_response, get_360_report, clear_responses |
| 通讯录 | 14 | query/add/delete_contacts, add/delete/restore_admin, list/add/modify/delete_departments, list/add/modify/delete_tags |
| 子账号 | 5 | add/modify/delete/restore/query_sub_accounts |
| SSO | 5 | sso_subaccount_url, sso_user_system_url, sso_partner_url, build_survey_url, build_preview_url |
| 分析计算 | 5 | decode_responses, calculate_nps, calculate_csat, detect_anomalies, compare_metrics |
| 用户体系 | 6 | add/modify/delete_participants, bind_activity, query_survey_binding, query_user_surveys |
| 诊断 | 1 | get_config — API Key(脱敏)、Base URL、CLI 版本、配置来源 |
详细参数见 references/tools-survey.md、references/tools-response.md、references/tools-other.md。
唯一推荐:所有问卷创建一律使用 create_survey_by_json(支持 70+ 题型,覆盖全部 q_type/q_subtype 编码)。
1. 使用 prompt 模板生成题目 JSON(如 generate-survey-json、generate-exam-json 等)
2. create_survey_by_json({ questions: [...], title: "问卷标题", atype: 1 })
3. get_survey({ vid: N }) — 验证内容
4. build_survey_url({ mode: "edit", activity: N }) — 提供编辑链接
create_survey_by_text(DSL 文本方式)已弃用,仅为兼容保留,新代码不要使用。
考试问卷(atype=6)注意:正确答案和每题分值无法通过 API 设置。创建后应提供编辑链接,指引用户在网页端配置答案与评分。
题型字段映射详见 wjx://reference/question-types 资源,或 references/dsl-and-types.md。
1. get_report({ vid: N }) — 统计概览(首选)
2. query_responses({ vid: N, page_size: 50 }) — 明细数据
3. decode_responses({ submitdata: "..." }) — 解码答卷格式
4. calculate_nps / calculate_csat — 分析指标
5. detect_anomalies({ responses: [...] }) — 数据质量检查
submitdata 题号必须与 get_survey 返回的原始 q_index 对齐——先拉结构再拼数据,不要凭"第几题"硬数:
1. get_survey({ vid, get_questions: true, get_items: true })
→ 拿到 questions[],每题含 q_index / q_type / q_subtype / items / item_rows
2. 按每题 q_type 拼 placeholder(举例):
- q_type=3(单选/量表/下拉) → `${q.q_index}$1`
- q_type=4(多选) → `${q.q_index}$1|2`
- q_type=4 + q_subtype=402(排序)→ `${q.q_index}$2|3|1`(按名次列出选项序号)
- q_type=5(填空) → `${q.q_index}$答案文本`
- q_type=6(多项填空) → `${q.q_index}$空1|空2|空3`
- q_type=7(矩阵):行用 item_rows.length 决定,逐行 `行号!列号`,行间用 `,` 拼
- q_type=10(滑动条) → `${q.q_index}$5`
3. 用 `}` 拼接所有题,得到完整 submitdata
4. submit_response({ vid, inputcosttime: 30, submitdata, ... })
— 内部会自动注入最新 jpmversion
跳过
q_type === 1(分页栏)和q_type === 2(段落说明),它们不接受答案。
| 错误现象 | 原因 | 解决方案 |
|---|---|---|
api_key 未设置 / API Key is required | 未配置 API Key | 停止当前业务操作,明确提醒用户去获取 API Key,并在 MCP 配置中添加 WJX_API_KEY |
"appkey error" / Invalid API Key | API Key 错误或过期 | 明确提醒用户重新获取 API Key,更新 MCP 配置后继续原任务 |
| "activity not found" | 问卷 vid 不存在 | list_surveys 确认正确 vid |
| "corp_id required" | 通讯录操作缺企业 ID | 配置 WJX_CORP_ID 环境变量 |
| 网络超时 | base_url 错误或网络不通 | get_config 检查 base_url |
| 创建问卷题目丢失 | DSL 格式错误 | 检查题号 + [题型标签],选项各占一行 |
更多排查详见 references/troubleshooting.md。
| 资源 URI | 内容 |
|---|---|
wjx://reference/dsl-syntax | DSL 文本语法(旧 create_survey_by_text 用,已弃用) |
wjx://reference/question-types | 题型和子类型完整映射表 |
wjx://reference/survey-types | 问卷类型编码(1=调查, 6=考试 等) |
wjx://reference/survey-statuses | 问卷状态码 |
wjx://reference/response-format | submitdata 编码格式 |
wjx://reference/analysis-methods | NPS/CSAT/CES 公式和行业基准 |
wjx://reference/user-roles | 子账号角色编码 |
wjx://reference/push-format | 数据推送格式和加密说明 |
通用/运维(6): design-survey, analyze-results, create-nps-survey, configure-webhook, anomaly-detection, user-system-workflow
分析(6): nps-analysis, csat-analysis, cross-tabulation, sentiment-analysis, survey-health-check, comparative-analysis
问卷生成 — DSL 文本(7,已弃用,保留兼容): generate-survey, generate-nps-survey, generate-360-evaluation, generate-satisfaction-survey, generate-engagement-survey, generate-exam-from-document, generate-exam-from-knowledge
问卷生成 — JSON(3,唯一推荐): generate-survey-json, generate-exam-json, generate-form-json
| 参数 | 值 |
|---|---|
| 问卷类型 (atype) | 1=调查, 2=测评, 3=投票, 6=考试, 7=表单 |
| 问卷状态 (state) | 1=发布, 2=暂停, 3=删除 |
| 下载格式 (suffix) | 0=CSV, 1=SAV, 2=Word |
| 角色 (roleid) | 1=系统管理员, 2=问卷管理员, 3=统计查看, 4=全部查看 |