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

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

image.png

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

@[toc]

前言

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);

示例代码

image.png

完整的代码示例如下:

    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。

示例代码

image.png

这个代码将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);

示例代码

image.png

完整的代码示例如下:

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);
相关文章
|
16天前
|
XML JSON 数据处理
C# 中的 XML 与 JSON 数据处理
在现代软件开发中,数据交换和存储需求日益增长,XML 和 JSON 成为最常用的数据格式。本文从 C# 角度出发,详细介绍如何处理这两种格式,并提供示例代码。对于 XML,我们介绍了读取、创建和写入 XML 文件的方法;对于 JSON,则展示了如何使用 Newtonsoft.Json 库进行数据解析和序列化。此外,文章还总结了常见问题及其解决方案,帮助开发者更好地应对实际项目中的挑战。
159 61
C# 中的 XML 与 JSON 数据处理
|
15天前
|
XML JSON JavaScript
js的json格式
js的json格式
|
15天前
|
JSON 数据格式
Blob格式转json格式,拿到后端返回的json数据
文章介绍了如何将后端返回的Blob格式数据转换为JSON格式,并处理文件下载和错误提示。
29 0
Blob格式转json格式,拿到后端返回的json数据
|
2天前
|
XML 存储 缓存
C#使用XML文件的详解及示例
C#使用XML文件的详解及示例
10 0
|
2天前
|
XML JSON 前端开发
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
33 0
|
14天前
|
JSON 数据格式 Python
6-1|Python如何将json转化为字符串写到文件内 还保留json格式
6-1|Python如何将json转化为字符串写到文件内 还保留json格式
|
2月前
|
Java Spring 容器
彻底改变你的编程人生!揭秘 Spring 框架依赖注入的神奇魔力,让你的代码瞬间焕然一新!
【8月更文挑战第31天】本文介绍 Spring 框架中的依赖注入(DI),一种降低代码耦合度的设计模式。通过 Spring 的 DI 容器,开发者可专注业务逻辑而非依赖管理。文中详细解释了 DI 的基本概念及其实现方式,如构造器注入、字段注入与 setter 方法注入,并提供示例说明如何在实际项目中应用这些技术。通过 Spring 的 @Configuration 和 @Bean 注解,可轻松定义与管理应用中的组件及其依赖关系,实现更简洁、易维护的代码结构。
37 0
|
5月前
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
171 3
|
5月前
|
SQL 开发框架 安全
C#编程与多线程处理
【4月更文挑战第21天】探索C#多线程处理,提升程序性能与响应性。了解C#中的Thread、Task类及Async/Await关键字,掌握线程同步与安全,实践并发计算、网络服务及UI优化。跟随未来发展趋势,利用C#打造高效应用。
182 3
|
17天前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
28 2