XML记一次带命名空间的xml读取
public static void ReadXML(string xmlUrl)
{
//判断文件是否存在
if (!File.Exists(xmlUrl))
{
Console.WriteLine($"文件路径不正确,没有查找到请确认路径:{xmlUrl}");
return;
}
//加载文档
XmlReaderSettings settings = new XmlReaderSettings();
settings.IgnoreComments = true;//忽略文档里面的注释
XmlDocument doc = new XmlDocument();
doc.Load(xmlUrl);
XmlNamespaceManager nameSpace = new XmlNamespaceManager(doc.NameTable);
nameSpace.AddNamespace("xs", "http://centiro.com/deliveryxml.xsd");
XmlElement resume = doc.DocumentElement;
//得到根节点shipments
XmlNode rootNode = resume;
// 得到根类shipment
XmlNode root = resume.SelectSingleNode("xs:shipment", nameSpace);
//XmlNode root = doc.ChildNodes.Item(0).ChildNodes.Item(0);
//得到shipment的子节点
//XmlNodeList rootAtt = root.ChildNodes;
//读取节点数据打印
foreach (XmlNode item in root)
{
Console.WriteLine($"当前节点名称:{item.Name.ToString()},---值:{item.InnerText.ToString()}"); }
//读取节点需要转化到数据库根据类名称
//XMLToClass(root, nameSpace);
shipment shipment = DeserializeXML<shipment>(rootNode.InnerXml); if (root.SelectSingleNode("xs:addresses", nameSpace) != null)
{
XmlNode addresses = root.SelectSingleNode("xs:addresses", nameSpace);
List<address> addressList = new List<address>();
foreach (XmlNode item in addresses)
{
address addre = new address();
Console.WriteLine($"------------------------------【addresses】-------------------------------------");
Console.WriteLine($"当前节点名称:{item.Name.ToString()},---值:{item.InnerText.ToString()}");
string xmlStr = "<address>" + item.InnerXml + "</address>";
addressList.Add(DeserializeXML<address>(xmlStr));
}
shipment.addresses = addressList;
} //如果需要转义保存
// doc.Save(@"textSave.xml"); }
然后下面是两种xml解析成对象的形式:
第一种变量赋值-很low:
public static void XMLToClass(XmlNode root, XmlNamespaceManager nameSpace)
{
//读取节点需要转化到数据库根据类名称
shipment shipment = new shipment();
shipment.operation = root.SelectSingleNode("xs:operation", nameSpace).InnerText;
shipment.deliveryMethod = root.SelectSingleNode("xs:deliveryMethod", nameSpace) == null ? "" : root.SelectSingleNode("xs:deliveryMethod", nameSpace).InnerText;
shipment.timeWindowDateFrom = root.SelectSingleNode("xs:timeWindowDateFrom", nameSpace).InnerText;
shipment.timeWindowDateTo = root.SelectSingleNode("xs:timeWindowDateTo", nameSpace).InnerText;
if (root.SelectSingleNode("xs:exchange", nameSpace) != null)
{
shipment.exchange = root.SelectSingleNode("xs:exchange", nameSpace).InnerText == "True" ? true : false;
}if (root.SelectSingleNode("xs:addresses", nameSpace) != null)
{
XmlNode addresses = root.SelectSingleNode("xs:addresses", nameSpace);
foreach (XmlNode item in addresses)
{
address addre = new address();
Console.WriteLine($"------------------------------【addresses】-------------------------------------");
Console.WriteLine($"当前节点名称:{item.Name.ToString()},---值:{item.InnerText.ToString()}");
DeserializeXML<address>(addresses.InnerXml); }
}
}
第二种序列化类实现:
public static T DeserializeXML<T>(string xmlStr)
{
//序列化前
xmlStr = xmlStr.Replace("xmlns=\"http://centiro.com/deliveryxml.xsd\"", "");
//序列化
using (StringReader reader = new StringReader(xmlStr))
{
XmlSerializer serializer = new XmlSerializer(typeof(T));
NameTable nt = new NameTable();
XmlNamespaceManager nsManager = new XmlNamespaceManager(nt);
nsManager.AddNamespace("one", "http://centiro.com/deliveryxml.xsd");
XmlParserContext context = new XmlParserContext(null, nsManager, null, XmlSpace.None);
XmlReaderSettings xmlReaderSettings = new XmlReaderSettings();
xmlReaderSettings.ConformanceLevel = ConformanceLevel.Fragment;
XmlReader xmlReader = System.Xml.XmlReader.Create(reader);
return (T)serializer.Deserialize(xmlReader);
}
}
这种最主要需要在类的上面添加:
[XmlRoot(Namespace = "", IsNullable = false, ElementName = "address")]
XML记一次带命名空间的xml读取的更多相关文章
- C#读取带命名空间的xml,xaml文件的解决方案
使用C#读取xml文件有三种常用的方式: 1.xmlDocument 2.XmlTextReader 3.Linq To Xml 但是这些方式在读写有些带命名空间的xml时就不知道怎么办了(例如把xa ...
- 由“Jasperrpeorts 4.1.2升级到5.1.2对flex项目的解析”到AS3 带命名空间的XML的操作
原文同步至:http://www.waylau.com/from-jasperrpeorts-4-1-2-upgraded-to-5-1-2-parsing-of-flex-projects-to-t ...
- 带命名空间的XML的dom4j应用<转>
Element root = document.getRootElement(); List recordenvlist = document.selectNodes("//gm ...
- dom4j解析带命名空间的xml文件
文件内容如下 <ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd=& ...
- C#读取带命名空间的xml
首先带有命名空间的xml读取可以使用Xml.Linq,也可以使用xpath,本文将采用xpath的方式解析. 原文参考了:https://www.cnblogs.com/duanjt/p/544054 ...
- Linq to xml 操作带命名空间的xml
昨天需要操作用代码操作csproj文件,实现不同vs版本的切换. 在用XElement读取了csproj文件以后怎么也获取不到想要的对象. 反反复复试验了好多次都不得要领:先看下csproj文件的内容 ...
- linq检索带命名空间的xml
XElement el = XElement.Load(fil); XNamespace ns = "http://schemas.microsoft.com/ado/2009/11/edm ...
- Linq to Xml读取复杂xml(带命名空间)
前言:xml的操作方式有多种,但要论使用频繁程度,博主用得最多的还是Linq to xml的方式,觉得它使用起来很方便,就用那么几个方法就能完成简单xml的读写.之前做的一个项目有一个很变态的需求:C ...
- Linq创建带命名空间、前缀、Soap格式的XML
关于XML,我也是刚接触,关于一般常见的XML,博客园.CSDN上的资料很多,对于不常见的带命名空间.前缀.Soap格式的XML的描述相对来说寥寥无几,上一篇我写到了对相对复杂的XML的读操作,下面说 ...
随机推荐
- Lua学习链接
Lua捕获 Lua中_G 是个什么鬼 Lua与ObjC的交互
- AI-2.梯度下降算法
上节定义了神经网络中几个重要的常见的函数,最后提到的损失函数的目的就是求得一组合适的w.b 先看下损失函数的曲线图,如下 即目的就是求得最低点对应的一组w.b,而本节要讲的梯度下降算法就是会一步一步地 ...
- sqlite3数据库教程
1.sqlite3安装(命令行): sudo apt-get install sqlite3 2.图形界面查看工具安装: sudo apt-get install sqlitebrowser 3.命令 ...
- 干货分享: 长达150页的openvswitch的ppt,不实验无真相
下载链接: Openvswitch实验教程 http://files.cnblogs.com/popsuper1982/Openvswtich.pptx 一.概论 Software Defined N ...
- Android OpenGL ES 开发(六): OpenGL ES 添加运动效果
在屏幕上绘制图形只是OpenGL的相当基础的特点,你也可以用其他的Android图形框架类来实现这些,包括Canvas和Drawable对象.OpenGL ES为在三维空间中移动和变换提供了额外的功能 ...
- SDL 开发实战(二):SDL 2.0 核心 API 解析
在上一篇文章 SDL 开发实战(一):SDL介绍及开发环境配置 中,我们配置好了SDL的开发环境,并成功运行了SDL的Hello World 代码.但是可能大部分人还是读不太明白具体Hello Wol ...
- [Swift]LeetCode7. 反转整数 | Reverse Integer
Given a 32-bit signed integer, reverse digits of an integer. Example 1: Input: 123 Output: 321 Examp ...
- [Swift]LeetCode249.群组偏移字符串 $ Group Shifted Strings
Given a string, we can "shift" each of its letter to its successive letter, for example: & ...
- [Swift]LeetCode307. 区域和检索 - 数组可修改 | Range Sum Query - Mutable
Given an integer array nums, find the sum of the elements between indices i and j (i ≤ j), inclusive ...
- JDBC也就那么回事
JDBC 一.JDBC概述 为什么要使用JDBC? JDBC:Java DataBase Connectivity,是SUN公司提供的一套操作数据库的标准规范(技术). JDBC与数据库驱动的关系:接 ...