Sublime Text 无法直接转换 JSON 为 XML,必须借助 Python 脚本+Build System 实现;因 JSON 与 XML 语义结构差异大,无统一映射标准,插件多已失效或仅简单包裹,不可靠。

Sublime Text 本身不支持直接将 JSON 转 XML,也没有内置的格式转换功能;必须借助插件 + 外部工具(如 Python 脚本或命令行工具)才能实现。纯靠插件“一键转换”基本不可靠,多数所谓“JSON to XML”插件早已停止维护、不兼容新版本 Sublime、或仅做简单标签包裹(不符合标准 XML 结构)。
为什么不能只装个插件就转成功
JSON 和 XML 语义结构差异大:JSON 的数组、嵌套对象、null 值、无属性概念,在 XML 中需约定映射规则(比如用 item 包裹数组元素,用 attr 表示属性,null 映射为 nil="true" 等)。没有统一标准,插件无法自动推断你的业务意图。
- 已下架的
JsonToXml插件仅把键名当标签名、值当文本内容,不处理嵌套和数组,生成的 XML 无法被标准解析器识别 -
ConvertToUTF8或XMLTools这类插件根本不提供 JSON→XML 功能,名字容易误导 - Sublime 的
Package Control当前(2024)搜索 “json xml convert” 无稳定可用插件
推荐方案:用 Python 脚本 + Sublime 的 Build System
最可控、可复用、不依赖第三方插件的方式。你需要一个轻量 Python 脚本完成转换逻辑,再通过 Sublime 的 Build System 把当前 JSON 文件传给它执行。
步骤如下:
- 安装 Python 3(确保终端中能运行
python3 --version) - 新建文件
json2xml.py,内容如下(使用标准库,无需额外 pip 安装):
#!/usr/bin/env python3
import json
import sys
import xml.etree.ElementTree as ET
from xml.dom import minidom
def json_to_xml_element(data, root_name="root"):
if isinstance(data, dict):
elem = ET.Element(root_name)
for key, value in data.items():
child = json_to_xml_element(value, key)
elem.append(child)
return elem
elif isinstance(data, list):
elem = ET.Element(root_name)
for i, item in enumerate(data):
child = json_to_xml_element(item, "item")
elem.append(child)
return elem
else:
elem = ET.Element(root_name)
elem.text = str(data) if data is not None else ""
return elem
if __name__ == "__main__":
if len(sys.argv) != 2:
print("Usage: python3 json2xml.py ")
sys.exit(1)
with open(sys.argv[1], "r", encoding="utf-8") as f:
data = json.load(f)
root = json_to_xml_element(data, "root")
rough_string = ET.tostring(root, encoding="unicode")
reparsed = minidom.parseString(rough_string)
print(reparsed.toprettyxml(indent=" "))
- 在 Sublime 中新建
Tools → Build System → New Build System,粘贴以下内容并保存为JSON2XML.sublime-build:
{
"shell_cmd": "python3 /path/to/json2xml.py \"$file\"",
"file_regex": "^.*$",
"selector": "source.json"
}
⚠️ 注意把 /path/to/json2xml.py 替成你实际存放脚本的绝对路径(如 /Users/you/scripts/json2xml.py)
- 打开一个
.json文件,按Cmd+B(macOS)或Ctrl+B(Windows/Linux),输出面板即显示格式化后的 XML
常见错误与绕过技巧
遇到报错别急着换插件,先查这几个点:
-
UnicodeEncodeError: 'charmap' codec can't encode character→ 在json2xml.py的open()中显式加encoding="utf-8"(上面脚本已包含) - Build 不生效 → 检查 Sublime 右下角是否显示
JSON语法高亮(不是Plain text),且文件已保存(未保存的临时内容无法被$file读取) - 输出 XML 缺少换行/缩进 → 上面脚本用了
minidom,已启用toprettyxml;若仍混乱,确认输入 JSON 本身是合法的(用json.loads()能通过) - 需要保留 null → 当前脚本把
null转为空文本;如需,得改写json_to_xml_element分支逻辑
真正可靠的 JSON→XML 转换永远要定义规则。Sublime 只是编辑器,不是转换引擎;把逻辑收在自己可控的脚本里,比找一个黑盒插件更省调试时间,也更容易适配后续需求变化。










