C# | JSON格式与XML格式互相转换

在这里插入图片描述

C# | JSON格式与XML格式互相转换

前言

JSON格式与XML格式是目前互联网上使用最为广泛的数据交换格式之一,而两种格式各自有着自己的特点和优势。
在实际开发中,我们经常需要将数据在不同的系统或模块之间进行传递和转换,而JSON格式和XML格式的互相转换是一项非常基础和必要的技能。
同时,对于需要将数据存储在不同的介质中的应用场景,比如在移动端本地存储数据,或者在服务器端将数据保存到文件或数据库中,也需要将JSON或XML格式进行相应的转换。
因此,熟练掌握JSON与XML格式互相转换的方法对于开发人员来说是非常重要的。在本文中,我们将介绍常用的JSON和XML互相转换的方法及其实现。

JSON转XML(XmlDocument)

将Json格式的数据转为XML不难,我们可以使用JsonConvert类将Json格式的字符串转为JObject对象,然后使用JObject对象中的方法将其转为XML格式的字符串。

实现步骤

第一步:将Json格式的字符串转为JObject对象。

            JObject jObject = JObject.Parse(jsonString);

第二步:创建一个XmlDocument对象,通过递归将Json逐级转化为XML格式,并将其添加到XmlDocument对象中。

            XmlDocument xmlDocument = new XmlDocument();
            xmlDocument.LoadXml("<?xml version=\"1.0\" encoding=\"utf-8\" ?><Root></Root>");
            XmlNode root = xmlDocument.SelectSingleNode("Root");
            AddJObjectToXmlNode(jObject, root);

示例代码

在这里插入图片描述

完整的代码示例如下:

    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            string jsonString = "{\"Table\":{\"Row\":[{\"Name\":\"张三\",\"Age\":\"20\"},{\"Name\":\"李四\",\"Age\":\"25\"}]}}";
            JObject jObject = JObject.Parse(jsonString);
            XmlDocument xmlDocument = new XmlDocument();
            xmlDocument.LoadXml("<?xml version=\"1.0\" encoding=\"utf-8\" ?><Root></Root>");
            XmlNode root = xmlDocument.SelectSingleNode("Root");
            AddJObjectToXmlNode(jObject, root);
            Console.WriteLine(xmlDocument.InnerXml);
        }

        private static void AddJObjectToXmlNode(JObject jObject, XmlNode parent)
        {
            foreach (var property in jObject.Properties())
            {
                var name = property.Name;
                var value = property.Value;

                if (value is JArray)
                {
                    foreach (var item in (JArray)value)
                    {
                        if (item is JObject)
                        {
                            var objectElement = parent.OwnerDocument.CreateElement(name);
                            parent.AppendChild(objectElement);
                            AddJObjectToXmlNode((JObject)item, objectElement);
                        }
                        else
                        {
                            var textElement = parent.OwnerDocument.CreateElement(name);
                            textElement.InnerText = item.ToString();
                            parent.AppendChild(textElement);
                        }
                    }
                }
                else if (value is JObject)
                {
                    var objectElement = parent.OwnerDocument.CreateElement(name);
                    parent.AppendChild(objectElement);
                    AddJObjectToXmlNode((JObject)value, objectElement);
                }
                else
                {
                    var textElement = parent.OwnerDocument.CreateElement(name);
                    textElement.InnerText = value.ToString();
                    parent.AppendChild(textElement);
                }
            }
        }
    }


JSON转XML(XDocument)

这部分内容更新于2023年5月15日

思路和之前一致,只不过使用的是XDocument来生成XML。

示例代码

在这里插入图片描述
这个代码将JSON对象转换为XElement对象,并根据JSON中的字段名生成XML节点。
创建一个XElement对象作为根,然后调用递归方法ConvertJObjectToXElement()来将JSON对象转换为XElement对象。

    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            string jsonString = "{\"Table\":{\"Row\":[{\"Name\":\"张三\",\"Age\":\"20\"},{\"Name\":\"李四\",\"Age\":\"25\"}]}}";
            JObject jObject = JObject.Parse(jsonString);

            XElement rootElement = new XElement("Root");
            ConvertJObjectToXElement(jObject, rootElement);
            XDocument xDocument = new XDocument(rootElement);

            Console.WriteLine(xDocument.ToString());
        }



        private static void ConvertJObjectToXElement(JObject jObject, XElement parentElement)
        {
            foreach (var property in jObject.Properties())
            {
                var value = property.Value;
                var name = property.Name;

                if (value is JValue)
                {
                    parentElement.Add(new XElement(name, value.ToString()));
                }
                else if (value is JObject)
                {
                    var childElement = new XElement(name);
                    parentElement.Add(childElement);
                    ConvertJObjectToXElement((JObject)value, childElement);
                }
                else if (value is JArray)
                {
                    foreach (var arrayValue in (JArray)value)
                    {
                        if (arrayValue is JObject)
                        {
                            var childElement = new XElement(name);
                            parentElement.Add(childElement);
                            ConvertJObjectToXElement((JObject)arrayValue, childElement);
                        }
                        else
                        {
                            parentElement.Add(new XElement(name, arrayValue.ToString()));
                        }
                    }
                }
            }
        }
    }

XML转JSON

其实将XML格式的数据转为Json也并不复杂。我们可以先将XML数据读取到DataSet中,然后再使用JsonConvert类将DataSet转为Json格式的字符串。

实现步骤

第一步:创建一个DataSet对象,并使用XmlReader读取XML格式的数据。

DataSet ds = new DataSet();
using (XmlReader reader = XmlReader.Create(new StringReader(xmlString)))
{
    ds.ReadXml(reader);
}

第二步:将DataSet对象转为Json格式的字符串。

string jsonString = JsonConvert.SerializeObject(ds, Formatting.Indented);

示例代码

在这里插入图片描述

完整的代码示例如下:

string xmlString = "<Table><Row><Name>张三</Name><Age>20</Age></Row><Row><Name>李四</Name><Age>25</Age></Row></Table>";
XmlDocument doc = new XmlDocument();
doc.LoadXml(xmlString);
string jsonString = JsonConvert.SerializeObject(doc, Newtonsoft.Json.Formatting.Indented);
Console.WriteLine(jsonString);
  • 4
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
对于复杂的JSON,可以使用递归算法将其转换为属性格式XML。以下是一个示例代码: ```csharp using Newtonsoft.Json.Linq; using System.Xml.Linq; // 将JSON字符串转换为JObject对象 string jsonStr = @" { 'name': 'John', 'age': 30, 'address': { 'street': '123 Main St', 'city': 'New York', 'state': 'NY', 'zip': '10001' }, 'phoneNumbers': [ { 'type': 'home', 'number': '555-1234' }, { 'type': 'work', 'number': '555-5678' } ] }"; JObject jsonObj = JObject.Parse(jsonStr); // 将JObject对象转换为XElement对象 XElement xml = ConvertJObjectToXElement(jsonObj, "Person"); Console.WriteLine(xml); private static XElement ConvertJObjectToXElement(JObject jsonObj, string elementName) { XElement element = new XElement(elementName); foreach (JProperty prop in jsonObj.Properties()) { if (prop.Value is JObject obj) { // 处理子对象 element.Add(ConvertJObjectToXElement(obj, prop.Name)); } else if (prop.Value is JArray arr) { // 处理数组 foreach (JObject objInArr in arr) { element.Add(ConvertJObjectToXElement(objInArr, prop.Name)); } } else { // 处理属性 element.Add(new XAttribute(prop.Name, prop.Value)); } } return element; } ``` 以上代码将复杂的JSON字符串转换为JObject对象,并使用递归算法将其转换为属性格式XML。输出结果如下: ```xml <Person Name="John" Age="30"> <address street="123 Main St" city="New York" state="NY" zip="10001" /> <phoneNumbers type="home" number="555-1234" /> <phoneNumbers type="work" number="555-5678" /> </Person> ``` 注意:上面的代码需要引用Newtonsoft.Json和System.Xml.Linq命名空间。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

猿长大人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值