先通过JObject解析JSON再递归生成XElement实现转换。使用Newtonsoft.Json解析JSON为JObject,遍历其节点递归构建XElement结构,数组用同名元素表示,最终生成XDocument。需注意JSON与XML数据模型差异,如数组处理、null值判断等。
在C#中,没有直接将JSON字符串转换为XML的内置方法,但可以通过中间解析步骤实现。通常的做法是先将JSON解析成对象或动态类型,再将其序列化为XML格式。以下是具体实现方式。
你需要先安装 Newtonsoft.Json 和使用 System.Xml.Linq 来操作XML。
示例代码:
using System;
using System.Xml.Linq;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
public class JsonToXmlConverter
{
public static XDocument ConvertJsonToXml(string json)
{
var doc = new XDocument();
var root = new XElement("root");
var obj = JObject.Parse(json);
FillXElement(root, obj);
doc.Ad
d(root);
return doc;
}
private static void FillXElement(XElement element, JToken token)
{
foreach (var child in token.Children())
{
if (child is JProperty prop)
{
if (prop.Value is JValue || !(prop.Value.HasValues))
{
var childElement = new XElement(prop.Name);
childElement.Value = prop.Value.ToString();
element.Add(childElement);
}
else
{
var childElement = new XElement(prop.Name);
FillXElement(childElement, prop.Value);
element.Add(childElement);
}
}
else if (child is JValue val)
{
element.Value = val.ToString();
}
}
}
}
使用示例:
string json = @"{ 'name': 'Alice', 'age': 30, 'address': { 'city': 'Beijing', 'zip': '100000' } }";
var xmlDoc = JsonToXmlConverter.ConvertJsonToXml(json);
Console.WriteLine(xmlDoc.ToString());
输出结果:
Alice 30Beijing 100000
例如:
"items": [ "apple", "banana" ]
可转换为:
- apple
- banana
只需在递归方法中判断 JArray 类型并循环处理即可。