wps-note
Compare original and translation side by side
🇺🇸
Original
English🇨🇳
Translation
ChineseWPS Note MCP Skill
WPS Note MCP Skill
核心操作模式:先定位(outline / search)→ 再读取(read)→ 最后编辑(write)。所有内容以语义 XML 格式交换,所有定位基于 (10 位字母数字)。
block_idCore Operation Mode: Locate first (outline / search) → Read next → Edit last. All content is exchanged in semantic XML format, and all positioning is based on (10 alphanumeric characters).
block_id何时使用
When to Use
- 用户提到 WPS 笔记、WPS Note、云笔记、金山笔记
- 用户要求读取、编辑、搜索、总结、翻译笔记内容
- 用户需要创建笔记、管理标签、整理笔记库
- 需要排查 MCP 工具调用失败(、
BLOCK_NOT_FOUND等错误)EDITOR_NOT_READY
不适用于:本地 Markdown 文件操作、WPS 文档/表格/演示等其他产品、纯概念讨论。
- Users mention WPS Notes, WPS Note, cloud notes, or Kingsoft Notes
- Users request to read, edit, search, summarize, or translate note content
- Users need to create notes, manage tags, or organize note libraries
- Need to troubleshoot MCP tool call failures (errors like ,
BLOCK_NOT_FOUND)EDITOR_NOT_READY
Not applicable to: Local Markdown file operations, other WPS products like documents/spreadsheets/presentations, or pure conceptual discussions.
核心概念
Core Concepts
Block 模型
Block Model
- 笔记由 block 组成,每个 block 有唯一的 。
block_id - block 类型:、
paragraph、heading、blockquote、code_block、list、table(单图/图片分栏)、image、horizontal_rule、highlight_block、columns、embed。note_audio_card - block(电子表格、视频、LaTeX、倒计时等)为只读占位符,不可编辑。
embed - block 为语音录音卡片(只读),在 XML 中显示为
note_audio_card,使用<NoteAudioCard/>工具获取转写内容。get_audio_transcript - 表格必须整表替换,无法编辑单个单元格。表格单元格仅支持简单块(段落、标题、引用、代码块、分隔线、图片),不可在单元格内嵌套高亮块、分栏、表格等容器类块。
- 容器嵌套限制:内仅支持简单块(段落、标题、引用、代码块、分隔线、图片),不可嵌套
<highlightBlock>、<highlightBlock>、<columns>。<table>的每个<columns>内支持简单块和<column>,不可嵌套<highlightBlock>或<table>。<columns>
- Notes are composed of blocks, each with a unique .
block_id - Block types: ,
paragraph,heading,blockquote,code_block,list,table(single image/image columns),image,horizontal_rule,highlight_block,columns,embed.note_audio_card - blocks (spreadsheets, videos, LaTeX, countdowns, etc.) are read-only placeholders and cannot be edited.
embed - blocks are voice recording cards (read-only), displayed as
note_audio_cardin XML. Use the<NoteAudioCard/>tool to obtain transcribed content.get_audio_transcript - Tables must be replaced in full; individual cells cannot be edited. Table cells only support simple blocks (paragraphs, headings, blockquotes, code blocks, horizontal rules, images), and cannot contain nested container blocks like highlight blocks, columns, or tables.
- Container Nesting Restrictions: only supports simple blocks (paragraphs, headings, blockquotes, code blocks, horizontal rules, images), and cannot nest
<highlightBlock>,<highlightBlock>, or<columns>. Each<table>within<column>supports simple blocks and<columns>, but cannot nest<highlightBlock>or<table>.<columns>
note_id
note_id
- 大部分工具需要 来指定操作的笔记。
note_id - 通过 或
list_notes获取search_notes;若用户要操作当前打开的笔记,可直接调用note_id获取。get_current_note - 可获取笔记元数据(含标签),支持三种模式:单个
get_note_info查询、批量note_id查询(最多 100 个)、全量分页浏览(note_ids/page/page_size),无需读取全文内容。limit
- Most tools require to specify the note to operate on.
note_id - Obtain via
note_idorlist_notes; if users want to operate on the currently open note, directly callsearch_notesto retrieve it.get_current_note - can retrieve note metadata (including tags), supporting three modes: single
get_note_infoquery, batchnote_idquery (up to 100 notes), and full pagination browsing (note_ids/page/page_size), without needing to read the full content.limit
XML 输入输出
XML Input/Output
- 所有内容以语义 XML 格式收发,使用标签如 、
<p>-<h1>、<h6>、<blockquote>、<codeblock>、<table>、<highlightBlock>等。<columns> - 每个块级标签通过 属性标识 block_id,如
id。<p id="aB3kLm9xZq">内容</p> - 重要:写入操作(等)的
edit_block/block_id只接受顶层 block ID(由anchor_id返回)。get_note_outlineXML 中容器(read_note、<highlightBlock>、<columns>)内部段落的<table>仅供阅读参考,不可用于写入操作。id - 写入时提供 XML 格式内容,系统自动转换为内部 block 模型。的目标 block 由工具参数
replace指定,block_id建议不写content;若显式写了根块id,必须与目标id一致。block_id时新内容中的块级标签应省略insert,系统自动分配新的id。block_id - 行内 mark 使用语义标签:、
<strong>粗体</strong>、<em>斜体</em>、<s>删除线</s>、<u>下划线</u>、<a href="url">链接</a>。<tag>#标签名</tag> - 标签写入:可在段落等行内内容中使用。文本必须以
<tag>#name</tag>开头;多级标签用#分隔(如/);id 属性可选,已有标签可通过<tag>#工作/项目</tag>获取 id 后传入,新标签可省略 id,系统自动创建。标签同步到左侧标签树自动完成。限制:find_tags优先放在笔记第一个 block(首行)中;每级最多 20 字、最多 10 级;不支持 emoji、空格、方括号等字符;<tag>不可嵌套在<tag>内(标签与链接互斥)。不合法内容会降级为纯文本并返回 warning。创建笔记后应在写入正文前先插入标签行;编辑已有笔记完成后若无标签也应补充。<a> - 行内自闭合元素:(表情)、
<emoji value="😀"/>(行内公式)、<latex formula="E=mc^2"/>(硬换行)。<br/> - 样式属性通过 传递:
<span>、<span fontColor="#C21C13">红色文字</span>、<span fontHighlightColor="#FBF5B3">高亮文字</span>。<span fontSize="16">大号文字</span> - 颜色受预设色板约束,任意 hex 色值会被编辑器静默丢弃。各类颜色预设值:
- (12 色):
fontColor#080F17#C21C13#DB7800#078654#0E52D4#0080A0#757575#DA326B#D1A300#58A401#116AF0#A639D7 - (9 色):
fontHighlightColor#FBF5B3#F8D7B7#F7C7D3#DFF0C4#C6EADD#D9EEFB#D5DCF7#E6D6F0#E6E6E6 - 颜色(6 对 bg→border):
highlightBlock→#FAF1E6、#FEC794→#FAE6E6、#F2A7A7→#E6FAEB、#AFE3BB→#E6EEFA、#98C1FF→#F5EBFA、#E5B5FD→#EBEBEB#C5C5C5 - (42 色,含纯色和渐变):
columnBackgroundColor- 6 基础色:
#FFF5EB#FFECEB#E8FCEF#EBF2FF#FAF0FF#F2F2F2 - 18 扩展纯色:
#FCFAE1#FEF6E7#FFF5ED#FFF2F0#FFF2F4#FFF0F7#EEFFEB#EBFFF5#E8FCFC#EBF8FF#EBF1FF#F0EDFF#F2E7E4#F0E6DA#F5EEDA#EDF0EB#EDEEF0#F0E4DD - 6 饱和色:
#FEF49C#BCFAAF#ADF4FF#C2D3FF#FFC7C7#E0E0E0 - 12 渐变色:使用 CSS 语法,如
linear-gradient()linear-gradient(133deg,#FFFAF7 2.14%,#FFEDFE 96.88%)
- 6 基础色:
- 完整 XML 格式参考已集成到 MCP Server Instructions 中自动注入(视客户端支持情况)。未注入时可调用 工具按需获取。
get_xml_reference
- All content is sent and received in semantic XML format, using tags such as ,
<p>-<h1>,<h6>,<blockquote>,<codeblock>,<table>,<highlightBlock>, etc.<columns> - Each block-level tag identifies the block_id via the attribute, e.g.,
id.<p id="aB3kLm9xZq">Content</p> - Important: The /
block_idfor write operations (such asanchor_id) only accepts top-level block IDs (returned byedit_block). Theget_note_outlineof paragraphs inside containers (id,<highlightBlock>,<columns>) in the<table>XML is for reading reference only and cannot be used for write operations.read_note - Provide content in XML format when writing; the system automatically converts it to the internal block model. For , the target block is specified by the tool parameter
replace, and it is recommended not to write theblock_idinid; if the root blockcontentis explicitly written, it must match the targetid. When usingblock_id, omit theinsertfrom block-level tags in the new content, and the system will automatically assign a newid.block_id - Inline marks use semantic tags: ,
<strong>bold</strong>,<em>italic</em>,<s>strikethrough</s>,<u>underline</u>,<a href="url">link</a>.<tag>#tagname</tag> - Tag Writing: can be used in inline content like paragraphs. The text must start with
<tag>#name</tag>; multi-level tags are separated by#(e.g.,/); the id attribute is optional—for existing tags, you can pass the id obtained via<tag>#work/project</tag>, while for new tags, omit the id and the system will automatically create it. Tags are automatically synchronized to the left tag tree. Restrictions:find_tagsshould be placed in the first block (first line) of the note; each level can have a maximum of 20 characters, with up to 10 levels; emojis, spaces, square brackets, and other characters are not supported;<tag>cannot be nested inside<tag>(tags and links are mutually exclusive). Invalid content will be degraded to plain text and return a warning. After creating a note, insert the tag line before writing the body; if there are no tags after editing an existing note, add them.<a> - Inline self-closing elements: (emoji),
<emoji value="😀"/>(inline formula),<latex formula="E=mc^2"/>(hard line break).<br/> - Style attributes are passed via :
<span>,<span fontColor="#C21C13">red text</span>,<span fontHighlightColor="#FBF5B3">highlighted text</span>.<span fontSize="16">large text</span> - Colors are constrained by preset palettes; arbitrary hex color values will be silently discarded by the editor. Preset values for various colors:
- (12 colors):
fontColor#080F17#C21C13#DB7800#078654#0E52D4#0080A0#757575#DA326B#D1A300#58A401#116AF0#A639D7 - (9 colors):
fontHighlightColor#FBF5B3#F8D7B7#F7C7D3#DFF0C4#C6EADD#D9EEFB#D5DCF7#E6D6F0#E6E6E6 - colors (6 bg→border pairs):
highlightBlock→#FAF1E6、#FEC794→#FAE6E6、#F2A7A7→#E6FAEB、#AFE3BB→#E6EEFA、#98C1FF→#F5EBFA、#E5B5FD→#EBEBEB#C5C5C5 - (42 colors, including solid and gradient):
columnBackgroundColor- 6 base colors:
#FFF5EB#FFECEB#E8FCEF#EBF2FF#FAF0FF#F2F2F2 - 18 extended solid colors:
#FCFAE1#FEF6E7#FFF5ED#FFF2F0#FFF2F4#FFF0F7#EEFFEB#EBFFF5#E8FCFC#EBF8FF#EBF1FF#F0EDFF#F2E7E4#F0E6DA#F5EEDA#EDF0EB#EDEEF0#F0E4DD - 6 saturated colors:
#FEF49C#BCFAAF#ADF4FF#C2D3FF#FFC7C7#E0E0E0 - 12 gradient colors: Use CSS syntax, e.g.,
linear-gradient()linear-gradient(133deg,#FFFAF7 2.14%,#FFEDFE 96.88%)
- 6 base colors:
- Complete XML format references are automatically integrated into MCP Server Instructions (depending on client support). If not injected, call the tool to obtain it on demand.
get_xml_reference
只读 Token
Read-Only Token
- 部分笔记 token 为只读,写入工具会返回 。
DOCUMENT_READ_ONLY - 此时 ——不要重试,应告知用户。读取操作不受影响。
retryable: false
- Some note tokens are read-only, and write tools will return .
DOCUMENT_READ_ONLY - In this case, —do not retry, inform the user instead. Read operations are not affected.
retryable: false
响应格式
Response Format
所有工具返回统一的标准信封:
json
{ "ok": true, "code": "OK", "message": "...", "retryable": false, "data": { ... }, "hints": [] }- ——调用是否成功。
ok - ——机器可读状态码(参见错误恢复)。
code - ——为
retryable时可直接重试。true - ——建议的后续工具或操作。
hints
All tools return a unified standard envelope:
json
{ "ok": true, "code": "OK", "message": "...", "retryable": false, "data": { ... }, "hints": [] }- —whether the call was successful.
ok - —machine-readable status code (see Error Recovery).
code - —if
retryable, you can retry directly.true - —suggested subsequent tools or operations.
hints
工作流
Workflow
1. 读取与理解笔记
1. Read and Understand Notes
get_current_note() → 获取 note_id + word_count + size_category(决定后续策略)
list_notes / search_notes → 按条件查找 note_id
get_note_outline(note_id) → 查看结构和 block ID(超大文档自动分页)
get_cursor_block() → 获取当前光标所在顶层 block_id
read_section(note_id, heading_id) → 读取某个章节
read_blocks(note_id, block_ids) → 批量读取指定 block
read_blocks(note_id, block_id, before, after) → 读取单个 block 及上下文
search_note_content(note_id, q) → 在笔记内搜索文本
read_image(note_id, block_id) → 读取图片 block 的实际内容(base64)
get_audio_transcript(shorthand_id) → 获取语音录音的转写内容
get_xml_reference() → 获取 XML 格式完整参考文档对于长笔记,优先使用 → ,而非 ,以减少 token 开销。
get_note_outlineread_sectionread_noteget_current_note() → Get note_id + word_count + size_category (determines subsequent strategy)
list_notes / search_notes → Find note_id by conditions
get_note_outline(note_id) → View structure and block IDs (automatically paginated for extra-large documents)
get_cursor_block() → Get the top-level block_id where the current cursor is located
read_section(note_id, heading_id) → Read a specific section
read_blocks(note_id, block_ids) → Batch read specified blocks
read_blocks(note_id, block_id, before, after) → Read a single block and its context
search_note_content(note_id, q) → Search text within the note
read_image(note_id, block_id) → Read the actual content of an image block (base64)
get_audio_transcript(shorthand_id) → Get transcribed content of voice recordings
get_xml_reference() → Get complete XML format reference documentFor long notes, prioritize using → instead of to reduce token overhead.
get_note_outlineread_sectionread_note分页读取大文档
Pagination for Reading Large Documents
当笔记超过 200 blocks 时,read_note 和 get_note_outline 的返回会自动分页——需通过 和 参数切换分页查看不同部分。笔记本身无 block 数量上限,这些参数仅控制单次读取返回量。
offsetblock_limitread_noteread_note({ note_id })
→ pagination: { total_blocks: 350, has_more: true, next_offset: 100 }
read_note({ note_id, offset: 100 })
→ pagination: { has_more: true, next_offset: 200 }
read_note({ note_id, offset: 200 })
→ pagination: { has_more: false } ← 读完也可手动控制每页大小:
read_note({ note_id, offset: 0, block_limit: 50 })get_note_outlinehas_more: truenext_offsetget_note_outline({ note_id, offset: next_offset })read_sectionnext_block_offsetblock_offsetread_section({ note_id, heading_block_id, max_blocks: 50 })
→ truncated: true, next_block_offset: 50
read_section({ note_id, heading_block_id, block_offset: 50 })
→ truncated: false ← 读完When a note has more than 200 blocks, the returns of read_note and get_note_outline will be automatically paginated—use the and parameters to switch pages and view different parts. There is no upper limit on the number of blocks in a note; these parameters only control the amount returned per read.
offsetblock_limitExample of :
read_noteread_note({ note_id })
→ pagination: { total_blocks: 350, has_more: true, next_offset: 100 }
read_note({ note_id, offset: 100 })
→ pagination: { has_more: true, next_offset: 200 }
read_note({ note_id, offset: 200 })
→ pagination: { has_more: false } ← Finished readingYou can also manually control the page size:
read_note({ note_id, offset: 0, block_limit: 50 })get_note_outlinehas_more: truenext_offsetget_note_outline({ note_id, offset: next_offset })read_sectionnext_block_offsetblock_offsetread_section({ note_id, heading_block_id, max_blocks: 50 })
→ truncated: true, next_block_offset: 50
read_section({ note_id, heading_block_id, block_offset: 50 })
→ truncated: false ← Finished reading文档大小策略
Document Size Strategy
get_current_noteget_note_outlineword_countsize_categoryestimated_xml_chars| size_category | 字数范围 | 策略 |
|---|---|---|
| <5K 字 | |
| 5K-20K 字 | |
| 20K-80K 字 | |
| >80K 字 | 同 large,精准定位优先 |
原则:文档越大,越应该用搜索定位而非顺序读取。对于 large/very_large 文档,优先使用 search_note_content 找到目标 block,再用 read_blocks 读取其上下文。操作当前笔记时,先调 获取 ,再决定路径。
get_current_notesize_categoryBoth and return , , and , based on which you can choose the reading strategy:
get_current_noteget_note_outlineword_countsize_categoryestimated_xml_chars| size_category | Word Count Range | Strategy |
|---|---|---|
| <5K words | Use |
| 5K-20K words | Use |
| 20K-80K words | Use |
| >80K words | Same as large; prioritize |
Principle: The larger the document, the more you should use search positioning instead of sequential reading. For large/very_large documents, first use search_note_content to find the target block, then use read_blocks to read its context. When operating on the current note, first call to get , then decide the path.
get_current_notesize_category2. 编辑笔记内容
2. Edit Note Content
get_note_outline(note_id) → 获取最新 block ID
get_cursor_block() → 当前围绕光标位置编辑时,获取锚点 block
read_blocks(note_id, [target_id]) → 确认当前内容
insert_image(note_id, anchor_id, pos, src) → 插入图片(独立工具,不走 XML,当前需联网)
generate_image(prompt, width?, height?) → AI 文生图,返回图片 URL(配合 insert_image 插入笔记)
edit_block(note_id, op, ...) → 单个编辑操作(替换、插入、删除、更新属性、移动)
batch_edit(note_id, operations) → 多个操作合并为一次原子事务关键:编辑后 block ID 可能变化。连续 insert 可直接使用返回的 做锚点;操作其他 block 前通过 刷新。
last_block_idget_note_outline参数约束: / 只传当前 需要的字段。 / 的 必须直接填写完整 XML 字符串,不能传纯文本、Markdown,或 这类自然语言编辑指令。
edit_blockbatch_editopreplaceinsertcontent"把第二段改成……"连续插入的正确做法(避免乱序):
- 优先:在一次 中将所有内容拼成完整 XML(如
insert),按 XML 顺序依次插入,无需分多次调用。"<h2>A</h2><p>...</p><h2>B</h2><p>...</p>" - 链式:如果必须分多次 ,每次使用上一次返回的
insert作为下一次的last_block_id,或在每次写入后调用anchor_id刷新 ID。get_note_outline
get_note_outline(note_id) → Get the latest block IDs
get_cursor_block() → Get the anchor block when editing around the current cursor position
read_blocks(note_id, [target_id]) → Confirm current content
insert_image(note_id, anchor_id, pos, src) → Insert image (independent tool, does not use XML, requires internet connection currently)
generate_image(prompt, width?, height?) → AI text-to-image, returns image URL (use with insert_image to insert into notes)
edit_block(note_id, op, ...) → Single edit operation (replace, insert, delete, update attributes, move)
batch_edit(note_id, operations) → Combine multiple operations into one atomic transactionKey: Block IDs may change after editing. For consecutive inserts, you can directly use the returned as the anchor; before operating on other blocks, refresh via .
last_block_idget_note_outlineParameter Constraints: / only pass the fields required for the current . The for / must be a complete XML string, not plain text, Markdown, or natural language editing instructions like "change the second paragraph to...".
edit_blockbatch_editopcontentreplaceinsertCorrect way to perform consecutive inserts (avoid out-of-order):
- Priority: Combine all content into a complete XML in one (e.g.,
insert), insert in XML order, no need to call multiple times."<h2>A</h2><p>...</p><h2>B</h2><p>...</p>" - Chained: If you must perform multiple inserts, use the returned from the previous call as the
last_block_idfor the next call, or callanchor_idto refresh IDs after each write.get_note_outline
3. 批量编辑(原子事务)
3. Batch Editing (Atomic Transaction)
单个操作使用 ,多个操作使用 合并为原子事务:
edit_blockbatch_editundefinedUse for single operations, and to combine multiple operations into an atomic transaction:
edit_blockbatch_editundefined单个操作
Single operation
edit_block(note_id, op: "replace", block_id: "id1", content: "<p>...</p>")
edit_block(note_id, op: "insert", anchor_id: "id2", position: "after", content: "<h2>...</h2><p>...</p>")
edit_block(note_id, op: "replace", block_id: "id1", content: "<p>...</p>")
edit_block(note_id, op: "insert", anchor_id: "id2", position: "after", content: "<h2>...</h2><p>...</p>")
多个操作(原子事务)
Multiple operations (atomic transaction)
batch_edit(note_id, operations: [
{ op: "delete", block_ids: ["id1"] },
{ op: "replace", block_id: "id2", content: "<p>...</p>" },
{ op: "update_attrs", block_id: "id3", attrs: { level: 2 } },
{ op: "move", block_id: "id5", anchor_id: "id2", position: "after" },
{ op: "insert", anchor_id: "id4", position: "after", content: "<h2>...</h2><p>...</p>" }
])
**执行顺序固定**(`batch_edit`):delete → replace → update_attrs → move → insert(与数组顺序无关)。batch_edit(note_id, operations: [
{ op: "delete", block_ids: ["id1"] },
{ op: "replace", block_id: "id2", content: "<p>...</p>" },
{ op: "update_attrs", block_id: "id3", attrs: { level: 2 } },
{ op: "move", block_id: "id5", anchor_id: "id2", position: "after" },
{ op: "insert", anchor_id: "id4", position: "after", content: "<h2>...</h2><p>...</p>" }
])
**Execution order is fixed** (for `batch_edit`): delete → replace → update_attrs → move → insert (regardless of array order).4. 管理笔记与标签
4. Manage Notes and Tags
get_note_info(note_id) → 获取单个笔记元数据(含标签)
get_note_info(note_ids: [...]) → 批量获取多个笔记元数据(最多 100 个)
get_note_info(page, page_size) → 分页浏览所有笔记元数据
search_notes(keyword, tags, since, before) → 搜索笔记(也可按标签筛选笔记)
create_note(title) → 创建空白笔记(需用 edit_block 添加内容)
import_web_page(url) → 从白名单域名导入网页为笔记(微信公众号、知乎、豆瓣等)
delete_note(note_id) → 不可恢复——必须与用户确认
sync_note(note_id) → 触发同步
find_tags() → 列出所有标签
find_tags(keyword) → 搜索标签
get_note_stats(detailed) → 使用统计get_note_info(note_id) → Get single note metadata (including tags)
get_note_info(note_ids: [...]) → Batch get metadata for multiple notes (up to 100)
get_note_info(page, page_size) → Browse all note metadata by page
search_notes(keyword, tags, since, before) → Search notes (can also filter by tags)
create_note(title) → Create blank note (need to add content with edit_block)
import_web_page(url) → Import web pages from whitelisted domains as notes (WeChat Official Accounts, Zhihu, Douban, etc.)
delete_note(note_id) → Irrecoverable—must confirm with user first
sync_note(note_id) → Trigger synchronization
get_note_stats(detailed) → Usage statistics工具速查表
Tool Cheat Sheet
读取/定位工具
Read/Location Tools
| 工具 | 用途 | 关键参数 |
|---|---|---|
| 获取结构大纲(含 title、word_count、block_count、size_category、estimated_xml_chars、blocks 列表、pagination)——获取 block_id 和文档规模的主要方式,超大文档自动分页 | |
| 获取当前光标所在顶层 block 的 | (无参数) |
| 按 ID 批量读取 block 的 XML 内容和属性,或读取单个 block 及前后上下文 | |
| 读取全文或分页读取(XML),超大文档自动分页并返回 pagination(含 has_more + next_offset) | |
| 在笔记内搜索文本,返回匹配 block 的 block_id/type/preview,用于编辑前定位 | |
| 按标题读取完整章节(到下一同级标题),截断时返回 next_block_offset 用于续读 | |
| 读取图片 block 的实际内容(base64),可供视觉理解 | |
| 获取语音录音(NoteAudioCard)的转写文本,返回句子列表(含说话人、时间戳) | |
| 获取 XML 格式完整参考文档(所有标签、属性、写入示例) | (无参数) |
示例:
get_note_outline({ note_id: "abc123" })
get_note_outline({ note_id: "abc123", offset: 100 }) // 分页续读
get_cursor_block()
read_blocks({ note_id: "abc123", block_ids: ["aB3kLm9xZq", "xY7nPq2wRt"] })
read_blocks({ note_id: "abc123", block_id: "xY7nPq2wRt", before: 2, after: 3 })
read_note({ note_id: "abc123" })
read_note({ note_id: "abc123", offset: 100 }) // 分页续读
read_note({ note_id: "abc123", offset: 0, block_limit: 50 }) // 手动控制每页大小
search_note_content({ note_id: "abc123", query: "季度总结" })
read_section({ note_id: "abc123", heading_block_id: "aB3kLm9xZq" })
read_section({ note_id: "abc123", heading_block_id: "aB3kLm9xZq", block_offset: 50 }) // 续读截断章节
read_image({ note_id: "abc123", block_id: "imgBlock01" })
get_audio_transcript({ shorthand_id: "sh_abc123" })
get_xml_reference()| Tool | Purpose | Key Parameters |
|---|---|---|
| Get structural outline (including title, word_count, block_count, size_category, estimated_xml_chars, blocks list, pagination) — main way to get block_id and document scale, automatically paginated for extra-large documents | |
| Get the | * (No parameters) * |
| Batch read XML content and attributes of blocks by ID, or read a single block and its surrounding context | |
| Read full text or paginated content (XML), automatically paginated for extra-large documents and returns pagination (including has_more + next_offset) | |
| Search text within the note, returns block_id/type/preview of matching blocks, used for positioning before editing | |
| Read a complete section by heading (until the next sibling heading), returns next_block_offset for continuation when truncated | |
| Read the actual content of an image block (base64), for visual understanding | |
| Get transcribed text of voice recordings (NoteAudioCard), returns list of sentences (including speaker, timestamp) | |
| Get complete XML format reference document (all tags, attributes, writing examples) | * (No parameters) * |
Examples:
get_note_outline({ note_id: "abc123" })
get_note_outline({ note_id: "abc123", offset: 100 }) // Continue reading with pagination
get_cursor_block()
read_blocks({ note_id: "abc123", block_ids: ["aB3kLm9xZq", "xY7nPq2wRt"] })
read_blocks({ note_id: "abc123", block_id: "xY7nPq2wRt", before: 2, after: 3 })
read_note({ note_id: "abc123" })
read_note({ note_id: "abc123", offset: 100 }) // Continue reading with pagination
read_note({ note_id: "abc123", offset: 0, block_limit: 50 }) // Manually control page size
search_note_content({ note_id: "abc123", query: "Quarterly Summary" })
read_section({ note_id: "abc123", heading_block_id: "aB3kLm9xZq" })
read_section({ note_id: "abc123", heading_block_id: "aB3kLm9xZq", block_offset: 50 }) // Continue reading truncated section
read_image({ note_id: "abc123", block_id: "imgBlock01" })
get_audio_transcript({ shorthand_id: "sh_abc123" })
get_xml_reference()写入工具
Write Tools
| 工具 | 用途 | 关键参数 |
|---|---|---|
| 单个编辑操作(推荐入口),编辑后 block_id 可能变化需重新获取。insert 操作返回 | |
| 多个操作的原子事务(全部成功或全部回滚),执行顺序固定。返回 | |
| 插入图片(图片不可通过 XML 创建,必须用此工具),当前走在线上传,返回 block_id 和尺寸 | |
| AI 文生图,返回图片 URL(配合 | |
| 从白名单域名(微信公众号、知乎、豆瓣等)导入网页内容为笔记,返回笔记 ID、标题和摘要。耗时 5-30 秒 | |
edit_blockbatch_edit | 必填字段 |
|---|---|
| |
| |
| |
| |
| |
contentreplaceinsert文件引用参数(CLI 和脚本场景):当 或 内容过大导致命令行截断时,可使用文件引用替代——(传入文件路径,Electron 读取后填入 )、(同理填入 )、(从 JSON 文件读取全部参数)。已有显式值时文件引用被忽略。详见 。
contentoperationscontent_filecontentoperations_fileoperations__args_filereferences/CLI_REFERENCE.md示例:
// 单个操作 — edit_block
edit_block({ note_id: "abc123", op: "replace", block_id: "xY7nPq2wRt", content: "<p>更新后的段落文本</p>" })
edit_block({ note_id: "abc123", op: "insert", anchor_id: "aB3kLm9xZq", position: "after", content: "<h2>新章节</h2><p>这里是新内容。</p>" })
edit_block({ note_id: "abc123", op: "delete", block_ids: ["xY7nPq2wRt", "kL5mNp8vBc"] })
edit_block({ note_id: "abc123", op: "update_attrs", block_id: "aB3kLm9xZq", attrs: { level: 2 } })
edit_block({ note_id: "abc123", op: "move", block_id: "imgBlock01", anchor_id: "aB3kLm9xZq", position: "after" })
// 多个操作(原子事务) — batch_edit
batch_edit({ note_id: "abc123", operations: [
{ op: "replace", block_id: "xY7nPq2wRt", content: "<p>更新后的段落文本</p>" },
{ op: "insert", anchor_id: "aB3kLm9xZq", position: "after", content: "<h2>新章节</h2>" }
]})
// 图片
insert_image({ note_id: "abc123", anchor_id: "aB3kLm9xZq", position: "after", src: "https://example.com/photo.png", alt: "示意图" })
// AI 文生图 → 插入笔记
generate_image({ prompt: "一只橘猫坐在窗台上,水彩画风格,暖色调" })
→ { image_url: "https://...", task_id: "...", width: 2688, height: 1536 }
// 然后用 insert_image 将返回的 image_url 插入笔记
// 导入网页为笔记
import_web_page({ url: "https://mp.weixin.qq.com/s/xxx" })
→ { fileId: "123456", title: "文章标题", intro: "摘要...", linkUrl: "https://xxx/note/123456" }| Tool | Purpose | Key Parameters |
|---|---|---|
| Single edit operation (recommended entry), block_id may change after editing and needs to be re-obtained. Insert operations return | |
| Atomic transaction for multiple operations (all succeed or all roll back), execution order is fixed. Returns | |
| Insert image (images cannot be created via XML, must use this tool), currently uses online upload, returns block_id and dimensions | |
| AI text-to-image, returns image URL (use with | |
| Import web content from whitelisted domains (WeChat Official Accounts, Zhihu, Douban, etc.) as notes, returns note ID, title, and abstract. Takes 5-30 seconds | |
Operation types for / :
edit_blockbatch_edit | Required Fields |
|---|---|
| |
| |
| |
| |
| |
contentreplaceinsertFile Reference Parameters (CLI and script scenarios): When or are too large to cause command line truncation, you can use file references instead— (pass file path, Electron reads it and fills into ), (fills into similarly), (reads all parameters from JSON file). Explicit values take precedence over file references. See for details.
contentoperationscontent_filecontentoperations_fileoperations__args_filereferences/CLI_REFERENCE.mdExamples:
// Single operation — edit_block
edit_block({ note_id: "abc123", op: "replace", block_id: "xY7nPq2wRt", content: "<p>Updated paragraph text</p>" })
edit_block({ note_id: "abc123", op: "insert", anchor_id: "aB3kLm9xZq", position: "after", content: "<h2>New Section</h2><p>This is new content.</p>" })
edit_block({ note_id: "abc123", op: "delete", block_ids: ["xY7nPq2wRt", "kL5mNp8vBc"] })
edit_block({ note_id: "abc123", op: "update_attrs", block_id: "aB3kLm9xZq", attrs: { level: 2 } })
edit_block({ note_id: "abc123", op: "move", block_id: "imgBlock01", anchor_id: "aB3kLm9xZq", position: "after" })
// Multiple operations (atomic transaction) — batch_edit
batch_edit({ note_id: "abc123", operations: [
{ op: "replace", block_id: "xY7nPq2wRt", content: "<p>Updated paragraph text</p>" },
{ op: "insert", anchor_id: "aB3kLm9xZq", position: "after", content: "<h2>New Section</h2>" }
]})
// Image
insert_image({ note_id: "abc123", anchor_id: "aB3kLm9xZq", position: "after", src: "https://example.com/photo.png", alt: "Diagram" })
// AI text-to-image → Insert into note
generate_image({ prompt: "An orange cat sitting on a windowsill, watercolor style, warm tones" })
→ { image_url: "https://...", task_id: "...", width: 2688, height: 1536 }
// Then use insert_image to insert the returned image_url into the note
// Import web page as note
import_web_page({ url: "https://mp.weixin.qq.com/s/xxx" })
→ { fileId: "123456", title: "Article Title", intro: "Abstract...", linkUrl: "https://xxx/note/123456" }隐藏写入工具
Hidden Write Tools
以下工具仍可用但默认不展示,适用于需要单独调用的场景:
| 工具 | 用途 | 关键参数 |
|---|---|---|
| 替换单个 block 内容 | |
| 在指定位置前后插入 | |
| 删除 block | |
| 修改 block 属性 | |
The following tools are still available but not displayed by default, suitable for scenarios that require separate calls:
| Tool | Purpose | Key Parameters |
|---|---|---|
| Replace content of a single block | |
| Insert before/after specified position | |
| Delete blocks | |
| Modify block attributes | |
管理工具
Management Tools
| 工具 | 用途 | 关键参数 |
|---|---|---|
| 列出笔记,支持排序和分页,返回 { notes, meta } | |
| 创建空白笔记(仅含空段落),返回 { fileId, title } | |
| 获取笔记元数据(不读全文),返回 title、时间、intro、tags、starred | |
| 获取当前笔记 ID、元数据和文档统计(含 word_count、size_category) | (无参数) |
| 获取当前光标所在 block 的 | (无参数) |
| 搜索笔记(关键词 + 标签交集 + 时间范围),也可仅传 tags 按标签浏览 | |
| 列出或搜索标签,返回 { id, name } 数组 | |
| 触发笔记与云端同步 | |
| 永久删除笔记(不可恢复),须先与用户确认 | |
| 使用统计(总笔记数、标签数、分布等) | |
| MCP 调用日志,用于诊断 | |
示例:
list_notes({ sort: "update_time", direction: "desc", limit: 10 })
list_notes({ starred: true }) // 仅列出已收藏笔记
search_notes({ keyword: "项目方案", tags: ["工作"], since: "2025-01-01T00:00:00Z" })
search_notes({ tags: ["工作"] }) // 按标签筛选笔记(替代原 list_tag_notes)
search_notes({ starred: true }) // 仅在已收藏笔记中搜索
create_note({ title: "会议记录 2025-03-03" })
get_current_note()
get_cursor_block()
get_note_info({ note_id: "abc123" }) // 单个笔记元数据(含标签)
get_note_info({ note_ids: ["abc123", "def456"] }) // 批量查询
get_note_info({ page: 1, page_size: 20 }) // 分页浏览所有笔记
get_note_info({ limit: 5 }) // 仅获取前 5 条
find_tags() // 列出所有标签
find_tags({ keyword: "工作" }) // 搜索标签
delete_note({ note_id: "abc123" }) // 不可恢复——必须先与用户确认!
get_mcp_logs({ limit: 20 }) // 查看最近的工具调用日志| Tool | Purpose | Key Parameters |
|---|---|---|
| List notes, supports sorting and pagination, returns { notes, meta } | |
| Create blank note (only contains empty paragraph), returns { fileId, title } | |
| Get note metadata (does not read full text), returns title, time, intro, tags, starred | |
| Get current note ID, metadata, and document statistics (including word_count, size_category) | * (No parameters) * |
| Get the | * (No parameters) * |
| Search notes (keyword + tag intersection + time range), can also pass only tags to browse by tag | |
| List or search tags, returns array of { id, name } | |
| Trigger synchronization between note and cloud | |
| Permanently delete note (irrecoverable), must confirm with user first | |
| Usage statistics (total notes, number of tags, distribution, etc.) | |
| MCP call logs, used for diagnosing | |
Examples:
list_notes({ sort: "update_time", direction: "desc", limit: 10 })
list_notes({ starred: true }) // List only starred notes
search_notes({ keyword: "Project Plan", tags: ["Work"], since: "2025-01-01T00:00:00Z" })
search_notes({ tags: ["Work"] }) // Filter notes by tag (replaces original list_tag_notes)
search_notes({ starred: true }) // Search only in starred notes
create_note({ title: "Meeting Minutes 2025-03-03" })
get_current_note()
get_cursor_block()
get_note_info({ note_id: "abc123" }) // Single note metadata (including tags)
get_note_info({ note_ids: ["abc123", "def456"] }) // Batch query
get_note_info({ page: 1, page_size: 20 }) // Browse all notes by page
get_note_info({ limit: 5 }) // Get only the first 5 entries
find_tags() // List all tags
find_tags({ keyword: "Work" }) // Search tags
delete_note({ note_id: "abc123" }) // Irrecoverable—must confirm with user first!
get_mcp_logs({ limit: 20 }) // View recent tool call logsBlock 类型与 XML 标签
Block Types and XML Tags
| Block 类型 | XML 标签 | 说明 |
|---|---|---|
| | 支持行内 mark( |
| | 级别由标签名或 |
| | 支持行内 mark 和 |
| | 纯文本内容;语言通过 |
| | 通过 |
| | |
| | 高亮块,仅支持简单块( |
| | 分栏布局,每个 column 支持简单块和 |
| | 只读——不可通过 XML 创建或修改,使用 |
| | 只读——图片分栏展示,不可通过 XML 创建 |
| | 分隔线 |
| | 只读——不可编辑或替换 |
| | 只读——语音录音卡片,使用 |
| Block Type | XML Tag | Description |
|---|---|---|
| | Supports inline marks ( |
| | Level is controlled by tag name or |
| | Supports inline marks and |
| | Plain text content; language is specified via |
| | Controlled by |
| | |
| | Highlight block, only supports simple blocks ( |
| | Column layout, each column supports simple blocks and |
| | Read-only—cannot be created or modified via XML, use |
| | Read-only—image column display, cannot be created via XML |
| | Horizontal rule |
| | Read-only—cannot be edited or replaced |
| | Read-only—voice recording card, use |
update_block_attrs
支持的属性
update_block_attrsAttributes Supported by update_block_attrs
update_block_attrs| Block 类型 | 属性 | 可选值 |
|---|---|---|
| | 1–6 |
| | |
| | |
| | 语言标识字符串 |
| | |
| Block Type | Attribute | Optional Values |
|---|---|---|
| | 1–6 |
| | |
| | |
| | Language identifier string |
| | |
Troubleshooting
Troubleshooting
block ID 失效(BLOCK_NOT_FOUND
)
BLOCK_NOT_FOUNDInvalid Block ID (BLOCK_NOT_FOUND
)
BLOCK_NOT_FOUND现象:写入操作报 ,即使之前刚读取过该 block。
原因:编辑操作会导致 block ID 变化,缓存的 ID 已过期。
解决:写入前总是先 或 刷新 ID;或使用上次 insert 返回的 作为下次 。
BLOCK_NOT_FOUNDget_note_outlinesearch_note_contentlast_block_idanchor_idSymptom: Write operations report , even though the block was just read.
Cause: Editing operations cause block IDs to change, and cached IDs are expired.
Solution: Always refresh IDs via or before writing; or use the returned from the previous insert as the next .
BLOCK_NOT_FOUNDget_note_outlinesearch_note_contentlast_block_idanchor_id表格编辑失败
Table Editing Failure
现象:尝试编辑表格单元格时报错或内容丢失。
原因:表格只支持整表替换,不能编辑单个单元格。
解决:用 的 操作传入完整的 XML 表格(含表头分隔行)。
edit_blockreplaceSymptom: Errors or content loss when trying to edit table cells.
Cause: Tables only support full replacement; individual cells cannot be edited.
Solution: Use the operation of to pass the complete XML table (including header separator row).
replaceedit_blockembed block 不可写
Embed Block Cannot Be Written
现象:对 embed block 调用 的 操作返回错误。
原因:电子表格、视频、音频、LaTeX 等嵌入内容为只读占位符。
解决:跳过 embed block,仅操作其他可编辑 block 类型。
edit_blockreplaceSymptom: Calling operation of on embed blocks returns an error.
Cause: Embedded content like spreadsheets, videos, audio, LaTeX, etc., are read-only placeholders.
Solution: Skip embed blocks and only operate on other editable block types.
replaceedit_block笔记只读(DOCUMENT_READ_ONLY
)
DOCUMENT_READ_ONLYRead-Only Note (DOCUMENT_READ_ONLY
)
DOCUMENT_READ_ONLY现象:所有写入操作均返回 。
原因:当前笔记 token 为只读权限,不可重试。
解决:告知用户此笔记为只读。读取操作仍正常。
DOCUMENT_READ_ONLYSymptom: All write operations return .
Cause: The current note token has read-only permission, cannot retry.
Solution: Inform the user that this note is read-only. Read operations still work normally.
DOCUMENT_READ_ONLY编辑器未就绪(EDITOR_NOT_READY
)
EDITOR_NOT_READYEditor Not Ready (EDITOR_NOT_READY
)
EDITOR_NOT_READY现象:操作返回 。
原因:笔记编辑器仍在初始化,通常 1-2 秒可恢复。
解决:等待片刻后重试。若 3 次仍失败,请用户检查笔记应用。
EDITOR_NOT_READYSymptom: Operations return .
Cause: The note editor is still initializing, usually recovers in 1-2 seconds.
Solution: Wait a moment and retry. If it fails 3 times, ask the user to check the note app.
EDITOR_NOT_READYWebSocket 未连接(WEBSOCKET_NOT_CONNECTED
)
WEBSOCKET_NOT_CONNECTEDWebSocket Not Connected (WEBSOCKET_NOT_CONNECTED
)
WEBSOCKET_NOT_CONNECTED现象: 返回 。
原因:网络断开或 WebSocket 连接中断。
解决:检查网络连接,等待 WebSocket 自动重连后重试。
get_audio_transcriptWEBSOCKET_NOT_CONNECTEDSymptom: returns .
Cause: Network disconnected or WebSocket connection interrupted.
Solution: Check network connection, wait for WebSocket to reconnect automatically and retry.
get_audio_transcriptWEBSOCKET_NOT_CONNECTED其他注意事项
Other Notes
- 图片必须使用 工具:图片不可通过 XML 创建(
insert_image标签为只读)。<img/>当前走在线上传,调用时需联网。支持 HTTP/HTTPS URL 和 base64 data URI。本地文件路径不支持直接传入,需先读取并转为 base64 data URI。URL 必须直接指向图片资源(返回 image/ 内容类型),不可为 HTML 页面链接*。若 URL 返回 404、离线或非图片内容,将报insert_image错误。IMAGE_FETCH_FAILED的 replace/insert/update_attrs 不支持图片(但 move 可以移动图片 block)。edit_block - 为 AI 文生图:返回图片 URL,而不是直接插入笔记。需配合
generate_image使用。每用户每分钟限 1 次,生成耗时约 30-120 秒。insert_image - 仅支持白名单域名:微信公众号、知乎、豆瓣等白名单域名可导入,非白名单域名会返回
import_web_page。转换耗时约 5-30 秒。导入完成后自动创建新笔记并跳转。INVALID_PARAMS - 执行顺序固定:delete → replace → update_attrs → move → insert,与数组顺序无关。
batch_edit - 操作支持所有 block 类型:包括图片(
move)、嵌入内容(<img/>)等无法通过 XML 创建的只读标签。移动后 block_id 保持不变,无需刷新 outline。适用于调整内容顺序、重新组织文档结构。<embed/> - 创建空白笔记:不支持初始内容,需用
create_note填充。edit_block - 仅限标题:
read_section必须指向heading_block_idblock,否则报heading。INVALID_BLOCK_TYPE - 仅支持顶层 block:光标位于高亮块(subdoc)或分栏(columns)内部时,会返回
get_cursor_block。UNSUPPORTED_POSITION - 不可恢复:必须先与用户确认。
delete_note - 当响应包含 时,遵循其建议——它们指明了最快的恢复路径。
hints
- Images must use the tool: Images cannot be created via XML (the
insert_imagetag is read-only).<img/>currently uses online upload, requires internet connection when called. Supports HTTP/HTTPS URLs and base64 data URIs. Local file paths are not supported directly; they need to be read and converted to base64 data URIs first. URLs must directly point to image resources (return image/ content type), not HTML page links*. If the URL returns 404, is offline, or is non-image content, it will reportinsert_imageerror.IMAGE_FETCH_FAILED's replace/insert/update_attrs does not support images (but move can move image blocks).edit_block - is AI text-to-image: Returns image URL, not directly inserted into notes. Need to use with
generate_image. Limit 1 time per user per minute, takes about 30-120 seconds to generate.insert_image - only supports whitelisted domains: Whitelisted domains like WeChat Official Accounts, Zhihu, Douban can be imported; non-whitelisted domains will return
import_web_page. Conversion takes about 5-30 seconds. After import, a new note is automatically created and opened.INVALID_PARAMS - execution order is fixed: delete → replace → update_attrs → move → insert, regardless of array order.
batch_edit - operation supports all block types: Including read-only tags that cannot be created via XML, such as images (
move), embedded content (<img/>), etc. Block_id remains unchanged after moving, no need to refresh outline. Suitable for adjusting content order and reorganizing document structure.<embed/> - creates blank note: Does not support initial content; need to fill with
create_note.edit_block - is limited to headings:
read_sectionmust point to aheading_block_idblock, otherwise it reportsheading.INVALID_BLOCK_TYPE - only supports top-level blocks: When the cursor is inside a highlight block (subdoc) or columns, it returns
get_cursor_block.UNSUPPORTED_POSITION - is irrecoverable: Must confirm with user first.
delete_note - When the response contains , follow the suggestions—they indicate the fastest recovery path.
hints
错误码速查
Error Code Quick Reference
| 错误码 | 可重试 | 恢复方法 |
|---|---|---|
| 否 | 按 inputSchema 修正参数 |
| 是 | 等待后重试 |
| 是 | 请用户打开笔记窗口 |
| 否 | 刷新大纲获取有效 ID |
| 否 | 检查 block 类型 |
| 否 | 修正内容格式 |
| 否 | 告知用户 |
| 是 | 缩小范围或重试 |
| 是 | 检查图片 URL 是否直接指向图片资源,修正后重试 |
| 否 | 修正 prompt 或检查白名单/登录状态 |
| 是 | 等待 60 秒后重试 |
| 是 | 检查网络,等待 WebSocket 重连后重试 |
| 是 | 重试;查 |
完整错误详情参见 。
references/ERROR_CODES.md| Error Code | Retryable | Recovery Method |
|---|---|---|
| No | Correct parameters according to inputSchema |
| Yes | Wait and retry |
| Yes | Ask user to open note window |
| No | Refresh outline to get valid IDs |
| No | Check block type |
| No | Correct content format |
| No | Inform user |
| Yes | Narrow scope or retry |
| Yes | Check if image URL directly points to image resource, correct and retry |
| No | Correct prompt or check whitelist/login status |
| Yes | Wait 60 seconds and retry |
| Yes | Check network, wait for WebSocket to reconnect and retry |
| Yes | Retry; check |
Complete error details can be found in .
references/ERROR_CODES.md常用编排模式
Common Orchestration Patterns
最高频的多工具组合,无需查阅完整用例手册即可使用。
模式 1:搜索定位 → 分段读取(长文档优先)
search_notes({ keyword }) → note_id
get_note_outline({ note_id }) → heading block ID
read_section({ note_id, heading_block_id }) → 按需读取章节模式 2:笔记内批量搜索替换
search_note_content({ note_id, query }) → 匹配的 block_id 列表
read_blocks({ note_id, block_ids }) → 读取完整内容
batch_edit({ note_id, operations: [{ op: "replace", ... }, ...] }) → 原子替换模式 3:创建 → 填充模板
create_note({ title }) → note_id(空白笔记)
get_note_outline({ note_id }) → 获取空 block ID
batch_edit({ note_id, operations: [
{ op: "replace", block_id, content: "<h1>标题</h1>" },
{ op: "insert", anchor_id, position: "after", content: "<p>模板内容...</p>" }
]})模式 4:连续追加多段内容(避免乱序)
undefinedThe most frequent multi-tool combinations, usable without referring to the complete use case manual.
Pattern 1: Search Positioning → Sectional Reading (priority for long documents)
search_notes({ keyword }) → note_id
get_note_outline({ note_id }) → heading block ID
read_section({ note_id, heading_block_id }) → Read sections as neededPattern 2: Batch Search and Replace in Notes
search_note_content({ note_id, query }) → List of matching block_ids
read_blocks({ note_id, block_ids }) → Read full content
batch_edit({ note_id, operations: [{ op: "replace", ... }, ...] }) → Atomic replacementPattern 3: Create → Fill Template
create_note({ title }) → note_id (blank note)
get_note_outline({ note_id }) → Get empty block ID
batch_edit({ note_id, operations: [
{ op: "replace", block_id, content: "<h1>Title</h1>" },
{ op: "insert", anchor_id, position: "after", content: "<p>Template content...</p>" }
]})Pattern 4: Append Multiple Sections Continuously (avoid out-of-order)
undefined方式 A(推荐):单次 insert 拼接完整 XML
Method A (recommended): Single insert with complete XML
edit_block({ note_id, op: "insert", anchor_id: "last_id", position: "after",
content: "<h2>第一部分</h2><p>内容 A</p><h2>第二部分</h2><p>内容 B</p>" })
edit_block({ note_id, op: "insert", anchor_id: "last_id", position: "after",
content: "<h2>Part 1</h2><p>Content A</p><h2>Part 2</h2><p>Content B</p>" })
方式 B:链式 insert,用上次返回的 last_block_id 做锚点
Method B: Chained insert, use last_block_id from previous return as anchor
edit_block({ ..., anchor_id: "id1", position: "after", content: "<h2>第一部分</h2><p>内容 A</p>" })
→ { last_block_id: "new_id_1" }
edit_block({ ..., anchor_id: "new_id_1", position: "after", content: "<h2>第二部分</h2><p>内容 B</p>" })
→ { last_block_id: "new_id_2" }
**模式 5:移动 block(图片、嵌入内容等)**get_note_outline({ note_id }) → 找到源 block 和目标位置
edit_block({ note_id, op: "move", block_id: "img_id", anchor_id: "target_heading", position: "after" })
→ block_id 不变,无需刷新 outline
**模式 6:分页读取超大文档**(无标题结构时优先,分页仅控制读取量,笔记无 block 上限)read_note({ note_id })
→ pagination: { total_blocks: 350, has_more: true, next_offset: 100 }
read_note({ note_id, offset: 100 })
→ pagination: { has_more: true, next_offset: 200 }
read_note({ note_id, offset: 200 })
→ pagination: { has_more: false } ← 读完
更多组合模式和端到端场景参见 `references/USE_CASES.md`。edit_block({ ..., anchor_id: "id1", position: "after", content: "<h2>Part 1</h2><p>Content A</p>" })
→ { last_block_id: "new_id_1" }
edit_block({ ..., anchor_id: "new_id_1", position: "after", content: "<h2>Part 2</h2><p>Content B</p>" })
→ { last_block_id: "new_id_2" }
**Pattern 5: Move Blocks (images, embedded content, etc.)**get_note_outline({ note_id }) → Find source block and target position
edit_block({ note_id, op: "move", block_id: "img_id", anchor_id: "target_heading", position: "after" })
→ block_id remains unchanged, no need to refresh outline
**Pattern 6: Paginate to Read Extra-Large Documents** (priority when there is no title structure; pagination only controls reading amount, no block limit for notes)read_note({ note_id })
→ pagination: { total_blocks: 350, has_more: true, next_offset: 100 }
read_note({ note_id, offset: 100 })
→ pagination: { has_more: true, next_offset: 200 }
read_note({ note_id, offset: 200 })
→ pagination: { has_more: false } ← Finished reading
More combination patterns and end-to-end scenarios can be found in `references/USE_CASES.md`.完整示例
Complete Example
用户说:"帮我找到 Q1 报告,更新摘要部分,加一个结论"
步骤 1:定位笔记
search_notes({ keyword: "Q1 报告" })
→ data.notes[0].note_id = "note_xyz"步骤 2:读取结构
get_note_outline({ note_id: "note_xyz" })
→ blocks: [
{ id: "h1abc", type: "heading", preview: "Q1 报告" },
{ id: "p1def", type: "paragraph", preview: "执行摘要..." },
{ id: "h2ghi", type: "heading", preview: "营收" },
{ id: "h2jkl", type: "heading", preview: "下一步计划" },
{ id: "p3mno", type: "paragraph", preview: "继续监控..." }
]步骤 3:确认当前内容
read_blocks({ note_id: "note_xyz", block_ids: ["p1def"] })
→ "本季度各部门..."步骤 4:原子编辑(替换摘要 + 插入结论)
batch_edit({ note_id: "note_xyz", operations: [
{ op: "replace", block_id: "p1def",
content: "<p>本报告涵盖 2025 年 Q1 各部门业绩表现。营收超出目标 15%。</p>" },
{ op: "insert", anchor_id: "p3mno", position: "after",
content: "<h2>总结</h2><p>2025 年 Q1 是强劲的一个季度,所有关键指标均实现显著增长。</p>" }
]})
→ ok: true, last_block_id: "new_conclusion_id"提示:/batch_edit的 insert 操作中,content 可包含多个块级 XML 元素(如上例的edit_block+<h2>),它们按 XML 顺序插入,无需分多次调用。返回的<p>可直接用于后续操作。last_block_id
步骤 5:验证结果
read_section({ note_id: "note_xyz", heading_block_id: "h1abc", max_blocks: 5 })
→ 确认摘要已更新、结论已添加结果:笔记摘要已替换为新内容,文末新增"总结"章节。
User says: "Help me find the Q1 report, update the summary section, and add a conclusion"
Step 1: Locate the note
search_notes({ keyword: "Q1 Report" })
→ data.notes[0].note_id = "note_xyz"Step 2: Read structure
get_note_outline({ note_id: "note_xyz" })
→ blocks: [
{ id: "h1abc", type: "heading", preview: "Q1 Report" },
{ id: "p1def", type: "paragraph", preview: "Executive Summary..." },
{ id: "h2ghi", type: "heading", preview: "Revenue" },
{ id: "h2jkl", type: "heading", preview: "Next Steps" },
{ id: "p3mno", type: "paragraph", preview: "Continue monitoring..." }
]Step 3: Confirm current content
read_blocks({ note_id: "note_xyz", block_ids: ["p1def"] })
→ "This quarter, each department..."Step 4: Atomic edit (replace summary + insert conclusion)
batch_edit({ note_id: "note_xyz", operations: [
{ op: "replace", block_id: "p1def",
content: "<p>This report covers the performance of all departments in Q1 2025. Revenue exceeded the target by 15%.</p>" },
{ op: "insert", anchor_id: "p3mno", position: "after",
content: "<h2>Conclusion</h2><p>Q1 2025 was a strong quarter, with all key indicators achieving significant growth.</p>" }
]})
→ ok: true, last_block_id: "new_conclusion_id"Tip: In the insert operation of/batch_edit, content can contain multiple block-level XML elements (likeedit_block+<h2>in the example), which are inserted in XML order without needing multiple calls. The returned<p>can be directly used for subsequent operations.last_block_id
Step 5: Verify results
read_section({ note_id: "note_xyz", heading_block_id: "h1abc", max_blocks: 5 })
→ Confirm summary is updated and conclusion is addedResult: The note summary has been replaced with new content, and a "Conclusion" section has been added at the end.
参考文档
Reference Documents
- API 参考——全部工具的完整 inputSchema
- CLI 参考——的 canonical 命令面、CLI 特有行为和 JSON 输出格式
wpsnote-cli - 错误码——详细错误码、hints 系统和恢复模式
- 用例手册——按复杂度递进的完整用例集(含端到端工作流示例)、Prompt 模板和异常处理速查
- API Reference——Complete inputSchema for all tools
- CLI Reference——Canonical command interface for , CLI-specific behaviors, and JSON output format
wpsnote-cli - Error Codes——Detailed error codes, hints system, and recovery modes
- Use Case Manual——Complete use case set (including end-to-end workflow examples) by complexity, prompt templates, and quick reference for exception handling