Json和Xml

一、前言

   学习心得: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 + ">";elsetext += "\r\n" + indent + "</" + node.Name + ">";}elsetext += " />";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文档中的不同节点。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/225978.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AGV智能搬运机器人-替代人工工位让物流行业降本增效

在当今快速发展的世界中&#xff0c;物流业面临着巨大的挑战&#xff0c;包括提高效率、降低成本和优化工作流程。为了应对这些挑战&#xff0c;一种新型的自动化设备——智能搬运机器人正在崭露头角。本文将通过一个具体的案例来展示富唯智能转运机器人在实际应用中的价值。 案…

Flask登陆后登陆状态及密码的修改和处理

web/templates/common 是统一布局 登录成功 后flask框架服务器默认由login.html进入仪表盘页面index.html(/),该页面的设置在 (web/controllers/user/index.py)&#xff0c;如果想在 该仪表盘页面 将 用户信息 展示出来&#xff0c;就得想办法先获取到 当前用户的 登陆状态。…

【项目】玩具租赁博客测试报告

目录 一、项目背景 二、项目功能 三、功能测试 一、项目背景 玩具租赁系统采用前后端分离的方法来实现&#xff0c;同时使用了数据库来存储相关的数据&#xff0c;同时将其部署到云服务器上。前端主要有十五个页面构成&#xff1a;用户注册、管理员注册、登录页、用户和管理…

1.倒排索引 2.逻辑斯提回归算法

1.倒排索引 https://help.aliyun.com/zh/open-search/retrieval-engine-edition/introduction-to-inverted-indexes 倒排索引&#xff08;Inverted Index&#xff09;是一种数据结构&#xff0c;用于快速查找包含某个特定词或词语的文档。它主要用于全文搜索引擎等应用&#…

Flask 与微信小程序对接

Flask 与微信小程序的对接 在 web/controllers/api中增建py文件&#xff0c;主要是给微信小程序使用的。 web/controllers/init.py # -*- coding: utf-8 -*- from flask import Blueprint route_api Blueprint( api_page,__name__ )route_api.route("/") def ind…

移动端Vant中的Calendar日历增加显示农历(节日、节气)功能

核心&#xff1a; 使用 js-calendar-converter 库实现 npm地址&#xff1a;js-calendar-converter 内部使用原生calendar.js&#xff0c; 中国农历&#xff08;阴阳历&#xff09;和西元阳历即公历互转JavaScript库&#xff0c;具体实现感兴趣的可自行查看其实现源码。 原日…

ElementUI的Table组件行合并上手指南

ElementUI的Table组件行合并 &#xff0c;示例用官网vue3版的文档 <el-table :data"tableData" :span-method"objectSpanMethod" border style"width: 100%; margin-top: 20px"><el-table-column prop"id" label"ID&qu…

【轻松入门】OpenCV4.8 + QT5.x开发环境搭建

引言 大家好&#xff0c;今天给大家分享一下最新版本OpenCV4.8 QT5 如何一起配置&#xff0c;完成环境搭建的。 下载OpenCV4.8并解压缩 软件版本支持 CMake3.13 或者以上版本 https://cmake.org/ VS2017专业版或者以上版本 QT5.15.2 OpenCV4.8源码包 https://github.com/op…

英语学习软件欧路词典 Eudic mac特点说明

欧路词典 Eudic mac是一款英语学习工具&#xff0c;它包含了丰富的英语词汇、短语和例句&#xff0c;并提供了发音、例句朗读、单词笔记等功能。 欧路词典 Eudic mac软件特点 多语种支持&#xff1a;欧路词典支持多种语言&#xff0c;包括英语、中文、日语、法语等等&#xff…

Havenask 分布式索引构建服务 --Build Service

Havenask 是阿里巴巴智能引擎事业部自研的开源高性能搜索引擎&#xff0c;深度支持了包括淘宝、天猫、菜鸟、高德、饿了么在内几乎整个阿里的搜索业务。本文针对性介绍了 Havenask 分布式索引构建服务——Build Service&#xff0c;主打稳定、快速、易管理&#xff0c;是在线系…

第27关 在K8s集群上使用Helm3部署最新版本v2.10.0的私有镜像仓库Harbor

------> 课程视频同步分享在今日头条和B站 大家好&#xff0c;我是博哥爱运维。 在前面的几十关里面&#xff0c;博哥在k8s上部署服务一直都是用的docker hub上的公有镜像&#xff0c;对于企业服务来说&#xff0c;有些我们是不想把服务镜像放在公网上面的&#xff1b; 同时…

【习题】运行Hello World工程

判断题 1. DevEco Studio是开发HarmonyOS应用的一站式集成开发环境。 正确(True)错误(False) 正确(True) 2. main_pages.json存放页面page路径配置信息。 正确(True)错误(False) 正确(True) 单选题 1. 在stage模型中&#xff0c;下列配置文件属于AppScope文件夹的是&am…

Docker自建私人云盘系统

Docker自建私人云盘系统。 有个人云盘需求的人&#xff0c;主要需求有这几类&#xff1a; 文件同步、分享需要。 照片、视频同步需要&#xff0c;尤其是全家人都是用的同步。 影视观看需要&#xff08;分为家庭内部、家庭外部&#xff09; 搭建个人网站/博客 云端OFFICE需…

【K8S 二进制部署】部署Kurbernetes的网络组件、高可用集群、相关工具

目录 一、K8S的网络类型&#xff1a; 1、K8S中的通信模式&#xff1a; 1.1、、pod内部之间容器与容器之间的通信 1.2、同一个node节点之内&#xff0c;不同pod之间的通信方式&#xff1a; 1.3、不同node节点上的pod之间是如何通信的呢&#xff1f; 2、网络插件一&#xff…

Linux下安装QQ

安装步骤&#xff1a; 1.进入官网&#xff1a;QQ Linux版-轻松做自己 2.选择版本&#xff1a;X86版下载dep 3安装qq 找到qq安装包位置&#xff0c;然后右击在终端打开输入安装命令&#xff0c;然后点击回车 sudo dpkg -i linuxqq_3.2.0-16736_amd64.deb 卸载qq 使用命令…

Windows/Linux环境登入mysql、mysqldump命令等多方式解决方案之简易记录

Windows/Linux环境登入mysql、mysqldump命令等多方式解决方案之简易记录 之前发布过Window方式,这次结合以上主题,完善下Linux相关登入方式过程,纯属做个记录,有需要的朋友可以做个学习参考。 一、Windows环境提示“‘mysql’ 不是内部或外部命令,也不是可运行的程序或批…

Flink项目实战篇 基于Flink的城市交通监控平台(下)

系列文章目录 Flink项目实战篇 基于Flink的城市交通监控平台&#xff08;上&#xff09; Flink项目实战篇 基于Flink的城市交通监控平台&#xff08;下&#xff09; 文章目录 系列文章目录4. 智能实时报警4.1 实时套牌分析4.2 实时危险驾驶分析4.3 出警分析4.4 违法车辆轨迹跟…

PO 发布SAP SProxy->外围系统 WebService

通信概览图 外围系统与PO、SAP的请求响应通信过程大致可以用下图描述 &#xff08;个人整理所得&#xff0c;可能有误&#xff0c;欢迎指正&#xff09; 1. 前期准备 1.1 外围系统提供WebService接口 以A系统的RFC发布WebService接口 RFC发布WebService接口 获取到WSDL地…

MATLAB遗传算法工具箱的三种使用方法

MATLAB中有三种调用遗传算法的方式&#xff1a; 一、遗传算法的开源文件 下载“gatbx”压缩包文件&#xff0c;解压后&#xff0c;里面有多个.m文件&#xff0c;可以看到这些文件的编辑日期都是1998年&#xff0c;很古老了。 这些文件包含了遗传算法的基础操作&#xff0c;包含…

【软件工程大题】数据流图_DFD图_精简易上手

数据流图(DFD)是一种图形化技术,它描绘信息流和数据从输人移动到输出的过程中所经受的变换。 首先给出一个数据流图样例 基本的四种图形 直角矩形:代表源点或终点,一般来说,是人,如例图的仓库管理员和采购员圆形(也可以画成圆角矩形):是处理,一般来说,是动作,是动词名词的形式…