Linq to XML的理解
1:这是一种比较好的操作Xml的工具。
àXDocument 文档
àXElement 元素
àXAttribute 属性
àXText 文本
2:这里还是和我们之前创建xml的形式是一样的,只是这里更为的简单点。
创建xmldocument节点,创建根元素,创建person元素,将person元素添加到根元素下面,在创建id属性这里是键值对形式,创建name,sex元素。并因为他们是对象,可以使用name.Value="阿辉";,通过add方法统一的保存到person元素。
public static void Main(string[] args) { var doc = new XDocument(); //创建根元素 var root = new XElement("root"); doc.Add(root); var person = new XElement("person"); XAttribute xId=new XAttribute("id","003"); XElement name=new XElement("name"); var sex = new XElement("dex"); name.Value = "阿辉"; sex.Value = "23"; person.Add(xId,name,sex); root.Add(person); doc.Save("ahuiLinq.xml"); }
3:再来一个简单的XML文档的形式。
直接就好像在写LINQ一样,直接就写完了。
static void Main(string[] args) { new XDocument( new XElement("root", new XElement("person", new XAttribute("id","002"), new XElement("name","ahji"), new XElement("age","23"), new XElement("sex","女") ))).Save("ahui02_XML.xml"); }
其实这里面的原理和之前我们写的那种形式的是一样的。我们只需要按照之前的顺序写下去就行了。
4:我们可以来好好的感觉下XML的强大之处。
_——》使用xml将数据库中的数据进行临时的保存
var xdoc=new XDocument(new XElement("PersonCollection")); Random random=new Random(); //我们可以从文本文件和DB中取到数据,保存到xml文件中。 for (int i = 0; i <100; i++) { xdoc.Root.Add( new XElement("Person", new XAttribute("id",i+1), new XElement("name","阿辉"+i), new XElement("age",random.Next(41)), new XElement("sex","男女"[random.Next(2)])) ); } xdoc.Save("Db中读取的数据.xml");
这里有一个小的知识点,我们发现在最后面那个有个男女的字符,但是后面直接跟了个[]这个是利用随机数是0,1来决定前面字符串中的位置,显示的是男或女。感觉很高端的样子。
new XElement("sex","男女"[random.Next(2)]))
5:直接将字符串转换为xml文档,那么就是在字符串中直接写代码就行了。
XDocument.Parse(@" <root> <person id=""004""> <name>阿辉</name> <age>23</age> <sex>男</sex> </person> </root> ").Save("stringToXml.xml");
这样的做法就比较之前的更加的简单了。
6:当xml文档的内容特别多,且我们需要某个文件的时候就需要使用我们查找的功能,
这里有具体的步骤。
*:加载xml文件
*:查找
*:具体的查找公式,这里的e是节点对象,也是属性,标签,这里主要进行判断。
//var query=xdoc.DescendantNodes().where(e=>{返回bool值得判断条件,其实这里就是写逻辑判断})+xdoc.DescendantNodes()返回全部的节点集合
string path = "Db中读取的数据.xml"; XDocument xdoc = XDocument.Load(path); var query = xdoc. DescendantNodes(). Where(e => { //返回Bool值得判断条件,e是节点对象,有属性,标签, XElement els = e as XElement; if (els == null) return false; XElement age = els.Element("age"); XElement sex = els.Element("女"); if(age !=null && sex !=null) { int numAge = Convert.ToInt32(age.Value); if (numAge >= 20 && numAge <= 25) { return true; } else { return false; } } else { return false; } }); XElement root=new XElement("root"); //这里遍历得到的数据就是XElement数据。 foreach (XElement item in query) { root.Add(item); } new XDocument(root).Save("Search.xml");