XmlDocument xDoc = new XmlDocument();
xDoc.Load("X.xml");
foreach (XmlElement elem in xDoc.SelectNodes("/data/a/item"))
Console.WriteLine(lst.InnerText);
Console.ReadKey();
static void Main(string[] args)
{
XmlDocument xDoc = new XmlDocument();
xDoc.Load("X.xml");
XmlNodeList lst = xDoc.ChildNodes[1].ChildNodes[1].ChildNodes  ;
游戏xml文件修改
for (int i=0;i< lst.Count ;i++)
Console.WriteLine(i.ToString()+lst.Item(i).Name );
foreach (XmlNode n in lst)
Console.WriteLine(n.Name  );
Console.ReadKey();
}
读取有namespace的Xml
<?xml version="1.0"encoding="utf-8"?>
<smmd:name xmlns:smmd="nxchj">
<smmd:a>1001</smmd:a>
<smmd:a>2001</smmd:a>
<smmd:a>10055</smmd:a>
<smmd:a>
<s>120011</s>
<ss>2000</ss>
</smmd:a>
</smmd:name>
static void Main(string[] args)
{
XmlDocument xDoc = new XmlDocument();
xDoc.Load("X.xml");
XmlNamespaceManager ns = new XmlNamespaceManager(xDoc.NameTable );
ns.AddNamespace("smmd", "nxchj");
foreach (XmlElement elem in xDoc.SelectNodes("/smmd:name/smmd:a",ns)) Console.WriteLine(elem.InnerText  );
Console.ReadKey();
}
C#操作xml
引用命名空间:using System.Xml
1.检查所要操作的xml文件是否存在:
System.IO.File.Exists(文件路径及名称);
2.得到xml文件:
(1)在asp中可以这样得到:
XmlDocument xmlDoc = new XmlDocument();
//导入xml文档
xmlDoc.Load( Server.MapPath("l"));
//导入字符串
//xmlDoc.LoadXml("<bookStore> <book id="01" price="3.5元"> 读者</book></bookStore>");
注:Server.MapPath("l")此时的l文件必须是在当前的解决方案里;同样可以写成完整的物理路径xmlDoc.Load (@"E:"软件学习"测试"l")
(2)在windForm中直接用物理路径得到所要操作的xml文件具体实现方法同上
3.创建xml文件:
XmlDocument xmlDoc = new XmlDocument(); //创建xml文档(实例化一个xml)
XmlNode root = xmlDoc.CreateElement("bookStore");//创建根节点
//创建第1个子结点:
XmlNode bookNode = xmlDoc.CreateElement("book");
bookNode.InnerText = "读者";
//为此节点添加属性
法1:
bookPublishNode.SetAttribute("id", "01")
root.AppendChild(bookNode);
法2:
XmlAttribute xmlattribute = tempXmlDoc.CreateAttribute("price");
xmlattribute.Value = "3.5元";
tempRoot .Attributes .Append (xmlattribute )
/
/创建第2个根节点的子结点:
XmlNode tempBookNode = xmlDoc.CreateElement("tempbook ");
tempBookNode.InnerText ="文摘";
root.AppendChild(tempBookNode);
c#操作Xml(一)
Xml作为一个非常重要的纯文本格式已经进入了编程的很多领域,作为一个面向应用层面的c#也一样在很多领域离不开Xml。
但是,c#在很多方面对Xml做了写封装,以至于很多操作Xml的代码,都不需要手动去写。例如,c#写WebService这种需要大量操作Xml的服务,除了极其个别的情况下,基本看不到任何操作Xml的代码。这是c#的一个优势,但是,最近发现正是这样一些c#的优势,导致了新一代c#程序员的能力退化。因为90%的情况下,不需要手动操作Xml,所以,年轻的c#程序员也觉得没必要为了这10%的情况,而去学如何手工读写Xml。真不知道,ms 提供了这么简便的工具,是ms做的善事还是作的孽。。。
好吧,废话就不说了,转入主题。
1.如何用Xml Dom的方式读取Xml
Xml Dom方式是最原始的一种操作Xml的途径,从 Framework 1.0开始就开始支持Dom方式。
1.1如何以Dom方式加载Xml
要读取Xml首先要加载Xml,加载的方式有两种,一种是从流或类似的Reader加载,例如:
当然还可以从字符串加载:
1.1读取无namespace的Xml
Xml已经准备好了,下面就开始读取这个Xml。现在希望读取data节下面的所有item中的text,那么就可以:
看看运行结果:
但是,这样写的问题有很多,例如在data节点中有非item的节点,这样访问,也就被无差别的把非item项也写出来了。例如把如果数据改成这样:
这样,在data节里面,除了4个item,还有一个other,这个other是不需要的,必须被排除掉,如果直接用第一中ChildNodes去访问的话,会得到这样的结果:
显然“!@#”也被选择出来了,这可不是我们所期望的,
所以,改用XPath的方式访问:
其运行结果为:
很好的other项排除在需要的节点外,这才是我们真正想要的结果:)
1.2读取有namespace的Xml
和c#一样Xml也有namespace,并且namespace在Xml中的作用巨大,也许你并未感受到namespace的作用,但是,你可能已经不得不面对那些有namespace的Xml了。
好吧,我们先加载一个有namespace的xml:
这里,我们准备了一个namespace——urn:vwxyzh,并且把这个namespace缩写成v。举个例子来说,v:data就是urn:vwxyzh这个namespace下面的data。
现在再用原来的XPath去跑一下:
Oh, no!一个也没有选择出来,为什么会这样哪?
因为原来的/data/item中的data节是没有namespace的data,和urn:vwxyzh的data不是一回事,所以,这个XPath根本定为不到任何节点。
必须要修改部分代码才能达到我们的目的,先来看看Select方法有哪些重载吧:
第一个重载,就是之前使用的那个,第二个重载,需要额外提供一个XmlNamespaceManager实例,一看名字就知道,这个实例是用于管理Xml的Namespace的。再查看一下这个类的成员:
可以发现,创建这个实例需要一个XmlNameTable,谁能提供这个XmlNameTable的实例哪?XmlDocument本身就提供了这个XmlNameTable:
c#操作Xml(二)
2 用Dom的方式创建/修改xml
上一篇讲了如何用dom的方式读一个xml,这一篇就讲一下如何用dom的方式去写一个xml。不过,用dom的写Xml本身并不是一个好主意,因为Dom方式本身的废话超多,做一个简单的事情就需要好几句语句,但是作为一个基本的方式还是有必要了解一下的。2.1 用Dom的方式去创建xml
如果想写出这样一个xml:
那么你可能需要这样一大段代码:
分析一下,在dom方式下要创建任何一个xml的节点都必须要使用XmlDocument的对应的Create方法创建,然后再添加到对应的位置,这也就是Dom方式最麻烦的地方。
看看运行结果:
这个xml和我们期望的xml是等价的,只是没有被格式好,好吧,想要一个格式化好的文档,那么就修改一下写xml的部分(在讲xmlwriter的时候还会讲到这个setting类):
再看看运行结果:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。