翼度科技»论坛 编程开发 .net 查看内容

开源.NetCore通用工具库Xmtool使用连载 - XML操作篇

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
【Github源码】


《上一篇》 介绍了Xmtool工具库中的发送短信类库,今天我们继续为大家介绍其中的XML操作类库。

XML操作是软件开发过程中经常会遇到的情况;包括XML内容的遍历解析,或者特定值内容的查询获取等等。Xmtool工具库提供了一种更方便的方式对Xml进行遍历解析或者对特定节点内容的获取,下面将详细说明。Xmtool工具库中提供了XmlTool类库,用以对Xml内容进行操作。该类库以回调方法的方式遍历XML内容的功能,使得Xml读取更灵活快捷,且能随时停止遍历过程;同时提供了将Xml内容反序列化为对象的能力,通过该方法可以将输入参数方便的转换成对象,更易于使用和控制。
当要使用这些功能时,需先获取XmlTool类库对象:
  1. XmlTool xml = Xmtool.Xml();
复制代码
针对遍历和反序列化功能根据输入源不同,XmlTool中为每个功能各自提供了 2 个方法。
Xml遍历方法:
Iterate        // 从文件加载Xml内容
IterateFromString        // 从字符串加载Xml内容
Xml反序列化方法:
Deserialize        // 从文件加载Xml内容
DeserializeFromString        // 从字符串加载Xml内容
1. Iterate

public void Iterate(string file, XmlNodeInfoGetter callback = null)

说明:从指定文件加载Xml内容并进行遍历,用户通过回调函数获取遍历信息

参数:

file: Xml文件全路径。
callbackXmlNodeInfoGetter类型回调函数,用于Xml节点和属性的读取。
  1. <xml>
  2.     <item name="Karl">It's a dog.</item>
  3.     <item name="Tom">It's a cat.</item>
  4. </xml>
复制代码
  1. private string mTomContent = "";
  2. private bool XmlReader(XmlNodeInfo node)
  3. {
  4.     if (!node.IsEndNode)
  5.     {
  6.         if (node.Path == "/xml/item")        // 当前节点是否/xml/item节点
  7.         {
  8.             if (node.GetAttribute("name") == "Tom")        // 当前节点name属性是否为Tom
  9.             {
  10.                 mTomContent = node.Text;        // 获取Tom的说明文本
  11.                 return false;        // 退出遍历
  12.             }
  13.         }
  14.     }
  15.     return true;
  16. }
  17. public void GetTomContent(string file)
  18. {
  19.         XmlTool xml = Xmtool.Xml();
  20.     xml.Iterate(file, XmlReader)
  21. }
  22. ReadXml("c:\demo.xml");
  23. Console.WriteLine(mTomContent)
复制代码
2. IterateFromString

public void Iterate(string content, XmlNodeInfoGetter callback = null)

说明:从指定字符串加载Xml内容并进行遍历,用户通过回调函数获取遍历信息

参数:

content: Xml格式的字符串内容。
callbackXmlNodeInfoGetter类型回调函数,用于Xml节点和属性的读取。
  1. string xmlData = @"<xml>
  2.                         <name>张三</name>
  3.                         <age>18</age>
  4.                         <gender>男</gender>
  5.                     </xml>";
  6. XmlTool xml = Xmtool.Xml();
  7. xml.IterateFromString(xmlData, (XmlNodeInfo node) =>
  8. {
  9.         if (!node.IsEndNode)
  10.     {
  11.         if (node.Path = "/xml/age")
  12.         {
  13.             Console.WriteLine("张三的年龄为:" + node.Text);
  14.             return false;
  15.         }
  16.     }
  17.     return true;
  18. })
复制代码
3. Deserialize

public dynamic Deserialize(string file, bool includeRoot = false)

说明:从指定文件加载Xml内容并进行解析,将解析内容反序列化为动态对象;暂不支持包含同层级同名称节点的Xml内容反序列化。

参数:

file: Xml文件全路径。
includeRoot:反序列化时是否包含根节点。
  1. <person>
  2.     <name>张三</name>
  3.     <age>18</age>
  4. </person>
复制代码
  1. XmlTool xml = Xmtool.Xml();
  2. dynamic person = xml.Deserialize("c:\demo.xml", false);
  3. Console.WriteLine("张三的年龄为:" + person.name.Value);
复制代码
4. DeserializeFromString

public dynamic DeserializeFromString(string xml, bool includeRoot = false)

说明:从字符串内容加载Xml并进行解析,将解析内容反序列化为动态对象;暂不支持包含同层级同名称节点的Xml内容反序列化。

参数:

content: Xml格式的字符串内容。
includeRoot:反序列化时是否包含根节点。
  1. string xmlData = @"<xml>
  2.                                         <person age="18" gender="男">张三</person>
  3.                     </xml>";
  4. XmlTool xml = Xmtool.Xml();
  5. dynamic person = xml.DeserializeFromString(xmlData);
  6. Console.WriteLine("张三的年龄为:" + person.person.age);
复制代码
附件说明

XmlNodeInfoGetter回调函数

public delegate bool XmlNodeInfoGetter(XmlNodeInfo nodeInfo);

说明:Xml遍历回调函数;Xml遍历到每个节点就会回调该方法一次,参数是遍历到的当前节点。

参数:

nodeInfo:当前节点信息。
名称类型说明
Path属性当前节点路径,同名路劲不区分;如:/xml/item
FullPath属性当前节点路径,区分同名路径;如:/xml/item[1]
LocalName属性节点去掉前缀的名称;如:\,该节点LocalName为item。
FullName属性节点全名称;如:\,该节点FullName为w:item。
NamespaceURI属性当前节点名称前缀对应的命名空间地址;没有前缀为空。
IsRoot属性当前节点是否根节点。
IsNode属性当前是否节点,起始节点或结束节点。
IsEndNode属性当前节点是否为结束节点;如:\
IsEmptyNode属性当前节点是否一个空节点;如:\
IsTextNode属性当前节点是否一个字符内容的节点。
IsCDATANode属性当前节点是否一个CDATA节点;如:\Text
Text属性当前节点的的字符串内容;需IsTextNode为true时有效。
CData属性当前节点的CDATA内容;需IsCDATANode为true时有效。
Level属性当前节点的深度层级。
Line属性当前节点在文件中的所在行数。
AttributeCount属性当前节点包含属性的个数。
HasAttributes()方法当前节点是否包含属性。
GetAttribute(int index)方法返回属性位置为index的属性值。
GetAttribute(string name)方法返回属性名称为name的属性值。
GetAttribute(string name, string namesapceURI)方法返回属性名为name,且name命名空间为namespaceURI的属性值。
GetAttributeName(int index)方法返回属性位置为index的属性名称。


【Github源码】


来源:https://www.cnblogs.com/bcbr/archive/2023/08/05/17608881.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具