如何使用Linq to XML读取XML
本文关键字:XML 读取 to Linq 何使用 | 更新日期: 2023-09-27 17:50:19
我的XML文件没有重复的信息(例如Feed XML文件)。我只需要从xml文件中选择一些信息。
<?xml version="1.0" encoding="UTF-8"?>
<root>
<client>
<Name>abc, xyz's</Name>
<DOB>2/1/1922</DOB>
<Number>1234567896</Number>
<Gender>unknown</Gender>
</client>
<Info>
<ID>1111111111</ID>
<Title>TITLE</Title>
</Info>
<BasicInfo>
<TransDate>3/16/2011</TransDate>
<Channel>1 + 1</Channel>
<Ind></Ind>
<Med></Med>
<Comment>This is comment</Comment>
</BasicInfo>
</root>
从上面的文件,我只需要以下元素的值:-
- 名称
- 标题
如何使用Linq to XML读取这个文件?请帮助。
Simple:
XDocument doc = XDocument.Load("feed.xml");
XElement client = doc.Root.Element("client");
string name = (string) client.Element("Name");
int number = (int) client.Element("Number");
XElement info = doc.Root.Element("Info");
string title = (string) info.Element("Title");
XElement basicInfo = doc.Root.Element("BasicInfo");
string comment = (string) basicInfo.Element("Comment");
可以更短,但是为不同的元素使用单独的变量将使调试更容易。当然,上面的代码根本没有错误检查…根据您的情况,您可能需要加载或不加载:)
在这里使用XPath是一个不错的选择:
XDocument doc = XDocument.Load("file.xml");
string name = (string)doc.XPathSelectElement("//root/client/Name");
string title = (string)doc.XPathSelectElement("//root/Info/Title");
string comment = (string)doc.XPathSelectElement("//root/BasicInfo/Comment");
没有错误检查,但如果你知道元素会在那里,这工作得很好。
以防你(像我一样)被迫使用VB。Net:),这里有一个可能的解决方案:
Dim xdoc As XDocument = <?xml version="1.0" encoding="UTF-8"?>
<root>
<client>
<Name>abc, xyz's</Name>
<DOB>2/1/1922</DOB>
<Number>1234567896</Number>
<Gender>unknown</Gender>
</client>
<Info>
<ID>1111111111</ID>
<Title>TITLE</Title>
</Info>
<BasicInfo>
<TransDate>3/16/2011</TransDate>
<Channel>1 + 1</Channel>
<Ind></Ind>
<Med></Med>
<Comment>This is comment</Comment>
</BasicInfo>
</root>
Console.WriteLine(xdoc.<root>.<client>.<Name>.Value())
Console.WriteLine(" {0}", xdoc.<root>.<client>.<Number>.Value())
Console.WriteLine(" {0}", xdoc.<root>.<Info>.<Title>.Value())
Console.WriteLine(" {0}", xdoc.<root>.<BasicInfo>.<Comment>.Value())