先写一个xml文件:
<?xml version="1.0" encoding="utf-8" ?>
<bookste>
<!--记录书本的信息-->
<book Type="必修课" ISBN="7-111-19149-2">
<title>编译原理</title>
<auth>佚名</auth>
<price>30.00</price>
</book> <book Type="选修课" ISBN="7-111-19149-1">
<title>计算机操作系统</title>
<auth>test</auth>
<price>28.00</price>
</book>
</bookste>
1.使用XmlDocument
使用XmlDocument来读取XML文件.在XML文件中,我们可以把XML看作是由文档声明(Declare),元素 (Element),属性(Attribute),文本(Text)等构成的一个树.最开始的一个结点叫作根结点,每个结点都可以有自己的子结点.得到一 个结点后,可以通过一系列属性或方法得到这个结点的值或其它的一些属性.例如:
1: xn 代表一个结点
2: xn.Name;//这个结点的名称
3: xn.Value;//这个结点的值
4: xn.ChildNodes;//这个结点的所有子结点
5: xn.ParentNode;//这个结点的父结点,等等...
1.1 读取所有的数据.
使用的时候,首先声明一个XmlDocument对象,然后调用Load方法,从指定的路径加载XML文件. : XmlDocument doc = new XmlDocument();
: doc.Load(@"..\..\Book.xml"); 然后可以通过调用SelectSingleNode得到指定的结点,通过GetAttribute得到具体的属性值.参看下面的代码 // 得到根节点bookste XmlNode xn = xmlDoc.SelectSingleNode("bookste"); // 得到根节点的所有子节点 XmlNodeList xnl = xn.ChildNodes; feach (XmlNode xn1 in xnl) { BookModel bookModel = new BookModel(); // 将节点转换为元素,便于得到节点的属性值 XmlElement xe = (XmlElement)xn1; // 得到ISBN两个属性的属性值 var isnb = xe.GetAttribute("ISBN").ToString(); // 得到Book节点的所有子节点 XmlNodeList xnl0 = xe.ChildNodes; var name=xnl0.Item().InnerText;
}
在正常情况下,上面的代码好像没有什么问题,但是对于读取上面的XML文件,则会出错,原因就是上面的XML文件里面有注释,在没有特别说明的情况下,会默认它也是一个结点(Node).所以在把结点转换成元素的时候就会报错."无法将类型为“System.Xml.XmlComment”的对象强制转换为类型 “System.Xml.XmlElement”。"解决方法如下,和newtonsoft.json这个库类似。
XmlDocument xmlDoc = new XmlDocument(); XmlReaderSettings settings = new XmlReaderSettings(); settings.IgneComments = true;//忽略文档里面的注释 XmlReader reader = XmlReader.Create(@"..\..\Book.xml", settings); xmlDoc.Load(reader);
2.使用XmlTextReader和XmlTextWriter
XmlTextReader和XmlTextWriter是以流的形式来读写XML文件.使用XmlTextReader读取数据的时候,首先创建一个流,然后用read()方法来不断的向下读,根据读取的结点的类型来进行相应的操作.如下:
以后继续....