使用Newtonsoft.Json和XmlDocument可高效转换XML到JSON,需注意混合内容处理、类型推断、数组生成及命名空间问题,通过忽略空节点、手动类型转换和结构预处理解决常见错误,结合性能优化策略提升处理效率。

在C#开发中,将XML转换为JSON是常见需求,尤其是在处理Web API、配置文件或跨平台数据交换时。虽然.NET提供了多种工具来实现这一功能,但在实际使用中容易遇到格式不一致、命名冲突、类型丢失等问题。以下是高效解析并转换XML到JSON的方法,以及常见错误与对应解决方案。
最常用且稳定的方式是结合 System.Xml 和 Newtonsoft.Json(也称 Json.NET)库。通过 XmlDocument 读取XML,再利用 JsonConvert.SerializeXmlNode() 实现转换。
示例代码:
using System.Xml;
using Newtonsoft.Json;
string xml = @"<person>
<name>张三</name>
<age>30</age>
<isStudent>false</isStudent>
</person>";
XmlDocument doc = new XmlDocument();
doc.LoadXml(xml);
string json = JsonConvert.SerializeXmlNode(doc, Newtonsoft.Json.Formatting.Indented);
Console.WriteLine(json);
输出结果为标准JSON格式:
{
"person": {
"name": "张三",
"age": "30",
"isStudent": false
}
}
该方法简洁高效,支持嵌套结构和属性处理。
当XML包含混合内容(如文本与子元素共存),默认转换可能生成不符合预期的JSON。
问题XML示例:
<description>这是一个<color>红色</color>的苹果</description>
直接转换后可能产生 #text 字段,影响可读性。
解决方案:
XML本身无类型概念,所有值均为字符串。默认转换下,<age>30</age> 会变成 "age": "30",而非数值。
解决方案:
示例:自动识别基本类型
JObject jObj = JObject.Parse(json);
foreach (var prop in jObj["person"].Children())
{
if (prop is JProperty p)
{
if (int.TryParse(p.Value?.ToString(), out int i))
p.Value = i;
else if (bool.TryParse(p.Value?.ToString(), out bool b))
p.Value = b;
}
}
多个同名元素应转为JSON数组,但若未正确包裹,会丢失结构。
错误XML:
<person><item>A</item><item>B</item></person>
期望输出:"item": ["A", "B"]
解决方案:
带有 <?xml version="1.0"?> 或命名空间(xmlns)的文档可能导致加载失败或字段带前缀。
解决方案:
基本上就这些。只要注意结构规范、类型处理和边界情况,C#中的XML到JSON转换可以既高效又可靠。关键是选择合适的工具链并提前处理典型陷阱。
以上就是C#如何高效解析并转换XML到JSON? 常见错误与解决方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号