Json和Xml

本文详细讲解了C#中的Json和Xml,涉及其概念、示例、模式创建、节点操作和转换XPath应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、前言

   学习心得:C# 入门经典第8版书中的第21章《Json和Xml》

二、Xml的介绍

Xml的含义:

        可标记性语言,它将数据以一种特别简单文本格式储存。让所有人和几乎所有的计算机都能理解。


XML文件示例:

<?xml version="1.0" encoding="utf-8"?>
<Books>
  <CSharp Time="2019">
    <book>C# 入门经典</book>
    <book>C# 高级编程</book>
    <book>C# 深入解析</book>
    <book>WPF 编程宝典</book>
  </CSharp>
  <Java>
  </Java>
</Books>

提示:

        节点:在Xml文件中有多个节点,节点就是<节点>:用来声明一个节点  </节点> 结束当前节点。如果在当前的节点中创建了节点那么就是称呼为给当前的节点创建了一个子节点。元素和特性可以统称为节点。 

        元素:元素的含义是指<></>这样的标签。

        特性:特性指某某元素的特性。如上述 Time 就是 Csharp的特性

三、Json的介绍

Json的含义:

        Json在我们C#开发当中会使用到的第二种数据语言。它主要使用在Wen服务中和Wen浏览器中。

Json文件示例:

{
  "?xml": {
    "@version": "1.0",
    "@encoding": "utf-8"
  },
  "Books": {
    "CSharp": {
      "@Time": "2019",
      "book": [ "C# 入门经典", "C# 高级编程", "C# 深入解析", "WPF 编程宝典" ]
    },
    "Java": ""
  }
}

示例解释:Json中使用{}表示数据块, 逗号分隔数据。[]为鉴定为数组。 冒号指定当前元素的值

提示:当前的Json示例与上面Xml示例存储的数据是一致的。 

四、Xml 模式介绍和创建

1 Xml 模式的介绍

         Xml模式是指在我们创建Xml文档时对文档的一种格式规范,使当前Xml文档不会出现不打算处理的数据。C#使用的标准模式xml格式时XSD(XML Schema Definition)

2 Xml 模式的创建

上述介绍可能不太能理解,我们创建一下就能理解了。共三步

2.1 打开Visual Studio 创建Xml文件

 

看到下面的页面则代表创建成功了

2.2  输入想要的Xml格式。(创建一个规范的Xml格式)

示例:

<?xml version="1.0" encoding="utf-8"?>
<Student>
	<Name name="">
		<Height>
			
		</Height>
		<Weight>
			
		</Weight>
		<Class>
			
		</Class>
	</Name>
</Student>

保存

 输入保存的名字以及路径

 2.3 创建XML模式(XML架构)

随后编译器为我们生成了一个Xsd后缀的一个文件

 一样的将当前文件保存。

 创建结束(创建了一个StudentXml 模式) 

3 Xml 文件模式使用

将上面我们创建的模式使用起来

3.1 先创建一个Xml文件(同样的方式)

3.2 指定使用的模式(使用的架构)

 如果表格中没有您创建的架构可以,在右侧添加。 

3.3 使用Xml模式(架构)

        在我们输入的时,智能提示就显示了我们之前的格式,可以帮助我们快速创建一个刚刚一样格式的Xml文件。

示例:

<?xml version="1.0" encoding="utf-8"?>
<Student>
	<Name name="张三">
		<Height> 188 </Height>
		<Weight>75kg</Weight>
		<Class>1805</Class>
	</Name>
</Student>

注意:如果您添加我们模式中没有的节点我们的编译器会报警告。


提示:如果您需要反复使用当前的模式建议把当前模式添加到Visual Studio中的XML架构中

五、读取和处理Xml文件

1 访问和处理Xml文件的类

类名描述
XmlNode表示文档中的一个元素。
XmlDocument读取存储在磁盘或网络地址上的Xml文件。
XmlElement表示一个元素,通常用来储存根目录。
XmlAttribute表示节点中的特性。
XmlText表示节点中的文本数据。
XmlComment表示特殊类型元素,不是Xml文件的一部分,用于便于阅读的其他拓展信息。
XmlNodeList表示一个元素集合。

举个例子:

  //XmlDocument 继承 XmlNode   
  XmlDocument document = new XmlDocument();
  document.Load(@"C:\Users\Administrator\Desktop\XMLFile2.xml");

示例解释:        

        XmlDocument 通过方法Load读取数据文件,参数为指定的Xml文件的路径,无返回类型。

//获取文档的根目录  也就获取了XML的所有文件内容。
XmlElement xmlElement= document.DocumentElement;

示例解释:

        (XmlDocument类型) DocumentElement属性返回当前Xml文件的根目录,如果没有则返回Null。

 //获取当前节点中后面的第一个节点
 XmlNode xmlNode = xmlElement.FirstChild;
 //获取当前节点中的最后一个节点
 XmlNode xmlNode1 = xmlElement.LastChild;
 //获取当前节点中的父节点
 XmlNode xmlNode2 = xmlElement.ParentNode;
 // 访问同一层级的下一个节点,而不考虑节点类型
 XmlNode xmlNode3 = xmlElement.NextSibling;
 //获取当前 是否有子节点
 Boolean IshaveXmlNode = xmlElement.HasChildNodes;

示例解释:

        我使用到了多种属性,类型都是一个节点XmlNode类型,代码当中都有相关注释。 


 其中:

        XmlText、XmlComment、XmlAttribute、XmlNode    是没有公共的无参构造函数或是抽象的类。但我们都可以通过 XmlDocument实例来创建

示例(读取Xml文件的节点)

 //获取所有节点
 foreach (XmlNode item in xmlElement.ChildNodes)
 {
     Console.WriteLine("根节点下有"+ item.Name + "节点");
     foreach (XmlNode item2 in item.ChildNodes)
     {
         Console.WriteLine($"{item.Name}节点下有"+ item2.Name+"节点");
     }
 }

示例解释:ChildNodes是获取当前节点的所有子节点 。

输出 :

 

2 示例(获取Xml内容,书上示例

   private string FormatText(XmlNode node, string text, string indent)
   {
       if (node is XmlText)
       {
           text += node.Value;
           return text;
       }

       if (string.IsNullOrEmpty(indent))
           indent = "";
       else
       {
           text += "\r\n" + indent;
       }

       if (node is XmlComment)
       {
           text += node.OuterXml;
           return text;
       }

       text += "<" + node.Name;
       if (node.Attributes.Count > 0)
       {
           AddAttributes(node, ref text);
       }
       if (node.HasChildNodes)
       {
           text += ">";
           foreach (XmlNode child in node.ChildNodes)
           {
               text = FormatText(child, text, indent + "  ");
           }
           if (node.ChildNodes.Count == 1 &&
              (node.FirstChild is XmlText || node.FirstChild is XmlComment))
               text += "</" + node.Name + ">";
           else
               text += "\r\n" + indent + "</" + node.Name + ">";
       }
       else
           text += " />";
       return text;
   }
  private void AddAttributes(XmlNode node, ref string text)
  {
      foreach (XmlAttribute xa in node.Attributes)
      {
          text += " " + xa.Name + "='" + xa.Value + "'";
      }
  }

 使用方式:

 XmlDocument document = new XmlDocument();
 document.Load(booksFile);
 textBlockResults.Text = FormatText(document.DocumentElement as XmlNode, "", "");

 示例解释:

        如其中的node is XmlText  来判断当前节点是否包含了文本 如前面的示例Class Weight  Height 这三个是XmlText 因为只有他们是实际包含了文本。其中的XmlComment判断也类似。

3 节点的操作

3.1 修改:

        可以通过Value 属性来获取,但如果不是实际包含了文本,那么返回结果就是Null


3.2 插入:

        前面提到 XmlText、XmlComment、XmlAttribute、XmlNode 其中我们可以通过XmlDocument使用方法来创建

举个例子:

  XmlDocument document = new XmlDocument(); 
  document.Load(booksFile);
  //创建一个特性
  document.CreateAttribute("特性");
  //创建一个节点 是什么类型,节点名称,"节点的Uri"
  document.CreateNode(XmlNodeType.Text,"名字","节点的名称空间 Uri");
  //创建一个XmlElement类型的节点 "
  document.CreateElement("节点名称");
  //创建一个XmlText类型的节点
  document.CreateTextNode("节点中显示的内容");
  //创建注释
  document.CreateComment("示例节点");

示例解释:展示了创建节点的多个方法。

将创建的节点添加进去:

  // 加载当前Xml文件
  XmlDocument document = new XmlDocument();
  document.Load(@"C:\Users\Administrator\Desktop\XMLFile3.xml");

  //获取根节点
  XmlElement root = document.DocumentElement;

  //创建节点 
  XmlElement newOther = document.CreateElement("Other");
  XmlComment comment = document.CreateComment("其他");
  XmlElement newXmlNode = document.CreateElement("FatherAndMother");
  XmlElement father = document.CreateElement("father");
  XmlElement mother = document.CreateElement("mother");
  XmlText liu = document.CreateTextNode("刘女士");
  XmlText li = document.CreateTextNode("李男士");

  //Other 节点下的节点
  newOther.AppendChild(newXmlNode);
  //Other节点的注释
  newOther.AppendChild(comment);
  //father and mother节点下的节点
  newXmlNode.AppendChild(father);
  newXmlNode.AppendChild(mother);
  //节点的文本
  mother.AppendChild(liu);
  father.AppendChild(li);

  root.InsertAfter(newOther,root.FirstChild);

  //保存文件
  document.Save(@"C:\Users\Administrator\Desktop\XMLFile3.xml");

效果:

 

3.3 删除

  XmlDocument document = new XmlDocument();
  document.Load(booksFile);
  XmlElement root = document.DocumentElement;
  if (root.HasChildNodes)
  {
      XmlNode book = root.LastChild;
      root.RemoveChild(book);
      document.Save(booksFile);
  }

3.4 选择

SerializeXmlNode返回第一个匹配的节点 

 XmlDocument document = new XmlDocument();
 document.Load(booksFile);
 //返回根目录
 string str = Newtonsoft.Json.JsonConvert.SerializeXmlNode(document);

六、XML转换为JSON

1安装Newtonsoft.Json 包

2 转换代码

 XmlDocument document = new XmlDocument();
 document.Load(@"C:\Users\Administrator\Desktop\XMLFile3.xml");
 string json = Newtonsoft.Json.JsonConvert.SerializeXmlNode(document);
 System.IO.File.WriteAllText(@"C:\Users\Administrator\Desktop\XMLFile2.json", json);

转换结果: 

{
  "?xml": {
    "@version": "1.0",
    "@encoding": "utf-8"
  },
  "Student": {
    "Name": {
      "@name": "张三",
      "Height": " 188 ",
      "Weight": "75kg",
      "Class": "1805"
    },
    "Other": {
      "FatherAndMother": {
        "father": "李男士",
        "mother": "刘女士"
      } /*其他*/
    }
  }
}

七、XPath搜索XML文件

SelectNodes方法通过Xpath表达式来对Xml进行查找

  XmlDocument document = new XmlDocument();
  document.Load(@"C:\Users\Administrator\Desktop\XMLFile3.xml");
  XmlNodeList  xmlNodeList= document.DocumentElement.SelectNodes(".") ;

示例解释:

        在XPath中,.代表当前节点。当你使用.时,它指代的是上下文中的当前节点。这通常用于在XPath表达式中指明相对位置,而不是从根节点开始定位节点。 

 1 Xpath表达式示例:

  1. 选择节点:

    • 选择所有节点: //*
    • 选择特定节点: /bookstore/book (选择根节点下的所有book节点)
    • 选择当前节点: .
  2. 按名称选择:

    • 选择所有名称为title的节点: //title
    • 选择当前节点的父节点: ..
    • 选择根节点: /
  3. 按属性选择:

    • 选择所有具有特定属性的节点: //*[@attribute]
    • 选择特定属性值的节点: //*[@attribute='value']
  4. 按位置选择:

    • 选择第一个节点: (//book)[1]
    • 选择最后一个节点: (//book)[last()]
    • 选择前几个节点: (//book)[position() <= 3]
  5. 按条件选择:

    • 选择价格大于 50 的书籍: //book[price > 50]
    • 选择作者为"Author Name"的书籍: //book[author='Author Name']
    • 选择第一个book节点的title: /bookstore/book[1]/title

这些表达式可以帮助你根据需要定位XML文档中的不同节点。

<think>好的,我现在需要处理用户的问题,比较JSONXML的区别及用途。首先,我得确认用户的需求是什么。用户可能是在数据交换或存储时面临选择,想知道哪种格式更适合他们的项目。我需要系统地整理两者的不同点各自的适用场景。 首先,回忆JSONXML的基本定义。JSON全称是JavaScript Object Notation,是一种轻量级的数据交换格式,基于JavaScript的子集,但现在独立于语言,广泛用于Web应用。XML是Extensible Markup Language,用于标记电子文件,使其具有结构性,常用于配置文件、Web服务等。 接下来,我需要比较它们的语法结构。JSON使用键值对,结构简洁,支持数组嵌套对象。例如,{"name": "John", "age": 30}。而XML使用标签,结构更冗长,比如<person><name>John</name><age>30</age></person>。JSON的语法更接近编程语言的数据结构,容易解析生成,而XML的结构更严格,需要闭合标签,可能更冗长。 然后考虑数据类型支持。JSON支持基本类型:字符串、数字、布尔值、数组、对象null。XML所有数据都是字符串,需要额外转换。这可能影响数据处理时的方便性。 可读性方面,两者都具备,但JSON更简洁,XML由于标签嵌套可能更复杂。不过XML的注释命名空间等功能在某些场景下有用,而JSON不支持注释。 解析难度方面,JSON在JavaScript中可以直接解析成对象,其他语言也有内置库,解析速度快。XML需要DOM或SAX解析器,处理起来更复杂,可能影响性能。 扩展性方面,XML通过XML Schema、命名空间等支持复杂数据结构,适合需要严格验证的场景。JSON虽然结构灵活,但缺乏类似的扩展机制,适合简单数据交换。 安全性方面,JSON可能面临注入攻击,比如JSON劫持,而XML有XXE(XML外部实体)攻击的风险,都需要正确处理。 应用场景方面,JSON常用于Web API、前后端通信、NoSQL数据库如MongoDB。XML在配置文件(如Spring)、企业级应用(SOAP Web服务)、文档处理(如DocBook)中常见。 还需要引用用户提供的参考资料,特别是引用[1]提到了JSONYAML的比较,但这里用户关注的是JSONXML,所以需要适当关联。引用[2]中提到的XML家族语言应用场景,可以加强XML用途部分的说明。 最后,生成相关问题,帮助用户进一步探索。比如数据量大的选择,如何转换格式,替代方案如YAML,安全性问题等。 在组织内容时,确保结构清晰,分点比较,使用用户指定的LaTeX格式,比如行内数学公式用$...$,但这里可能较少涉及数学,但如果有数据结构的示例,需要用正确的语法。独立公式可能不需要,但如果有,要用$$...$$。同时检查语法正确,用中文回答,引用标识自然添加。 总结,我需要分结构差异、数据类型、可读性、解析、扩展性、安全性应用场景来展开,每部分简明扼要,引用相关资料,最后生成相关问题。</think>### JSON vs XML: 数据交换格式的差异与应用场景 #### 1. **结构差异** - **JSON**:基于键值对的轻量级结构,语法与编程语言(如JavaScript)的对象模型直接对应。 示例: ```json { "name": "Alice", "age": 30, "hobbies": ["reading", "coding"] } ``` - **XML**:基于标签的树状结构,强调数据的层次性与自描述性。 示例: ```xml <person> <name>Alice</name> <age>30</age> <hobbies> <hobby>reading</hobby> <hobby>coding</hobby> </hobbies> </person> ``` JSON的语法更紧凑,而XML的结构更适合复杂文档[^1]。 #### 2. **数据类型支持** - **JSON**:原生支持基本数据类型(字符串、数字、布尔值、数组、对象、`null`)。 - **XML**:所有数据均为字符串,需通过额外定义(如XML Schema)实现类型约束。 例如,XML需要显式标注数值类型: ```xml <age type="integer">30</age> ``` #### 3. **可读性与复杂度** - **JSON**:简洁易读,适合快速开发,但缺乏注释功能。 - **XML**:标签嵌套可能增加复杂度,但支持注释、命名空间等特性,适合企业级配置[^2]。 #### 4. **解析与性能** - **JSON**:解析速度快,JavaScript中可直接通过`JSON.parse()`处理,其他语言也提供高效解析库。 - **XML**:解析需DOM或SAX解析器,内存占用较高,处理大型文件时性能较低。 #### 5. **扩展性与标准化** - **JSON**:灵活性高,但缺乏内置验证机制(如JSON Schema非强制)。 - **XML**:支持XML Schema、DTD等严格验证工具,适合需要强数据约束的场景(如金融协议)。 #### 6. **安全性** - **JSON**:需防范JSON注入攻击(如恶意脚本注入)。 - **XML**:存在XXE(XML外部实体)攻击风险,需禁用外部实体解析。 #### 7. **典型应用场景** | **场景** | **JSON** | **XML** | |-------------------------|---------------------------------------|------------------------------------------| | Web API交互 | RESTful API主流格式(如Twitter API) | 传统SOAP Web服务(如银行系统) | | 配置文件 | 简单配置(如npm的`package.json`) | 复杂配置(如Spring框架的`applicationContext.xml`) | | 数据存储 | NoSQL数据库(如MongoDB) | 文档存储(如Microsoft Office Open XML) | | 跨平台数据交换 | 移动端应用(如Android/iOS) | 企业系统集成(如EDI电子数据交换) | --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

学软件开发的猪

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

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

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

打赏作者

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

抵扣说明:

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

余额充值