通过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.

通过linq从XML中获取值

您需要指定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 nsvar ns

相关文章: