通过linq从XML中获取值
本文关键字:获取 XML linq 通过 | 更新日期: 2023-09-27 18:24:54
所以我根本不愿意发布它,因为已经有无数关于它的文档了。我接触LINQ已经两年了,现在它在挖苦我。经过3个小时的连续尝试和失败,我决定做我不愿意做的事。将它发布到So。
我有这个XML
<TopMost xmlns="http://abc.com/">
<Mine>MyName</Mine>
<Hello>
<File>SIMPLE</File>
<Book>20</Book>
<Copy>0</Copy>
</Hello>
</TopMost>
我只想得到"文件"、"书本"、"副本"的值。并想将其与单元测试中的内容进行比较。
我找到了这个:
string result = string.Empty;
const string path = @"C:'Library.xml";
XDocument xdoc = XDocument.Load(path);
var lv1s = from paper in xdoc.Descendants("Hello")
select new
{
fileP = paper.Element("File").Value,
bookP = paper.Element("Book").Value,
copyP = paper.Element("Copy").Value,
};
result += lv1s.fileP + lv1s.bookP + lv1s.copyP; // Error
MessageBox.Show(result);
错误:序列不包含元素
我知道必须有一个简单的方法,但我远非如此。我有很多这样的代码片段,我尝试过,但都失败了。
编辑
var lv1s = from paper in xdoc.Descendants(ns + "Hello")
select new
{
fileP = paper.Element(ns + "File").Value,
bookP = paper.Element(ns + "Book").Value,
copyP = paper.Element(ns + "Copy").Value,
};
我收到编译错误。
Error: The Name ns doex not exist in current context.
您需要指定namespcae:
XNamespace ns = "http://abc.com/"; // or: doc.Root.GetDefaultNamespace()
var lv1s = from paper in xdoc.Descendants( ns + "Hello")
select new
{
fileP = paper.Element(ns +"File").Value,
bookP = paper.Element(ns +"Book").Value,
copyP = paper.Element(ns +"Copy").Value,
};
不要试图使用string ns
或var ns
。