Linq to XML查询返回null

时间:2015-11-28 22:12:24

标签: c# xml linq linq-to-xml

我有以下XML文件:

<?xml version="1.0" encoding="utf-8"?>
<tmx version="1.4">
  <header/>
  <body>
    <tu>
      <tuv lang="en">
        <seg>Hello?</seg>
      </tuv>
      <tuv lang="es">
        <seg>¿Diga?</seg>
      </tuv>
    </tu>
  </body>
</tmx>

我正在尝试使用此代码检索第一个<seg>代码的内容:

root.Elements("tuv")
    .Where(e => e.Attribute("lang").Value.Equals("en"))
    .Select(e => e.Elements("seg"))
    .SingleOrDefault()
    .Where(d => d.Value.Equals(originalText))
    .SingleOrDefault()
    .Value;

originaltext等于“你好?”在这种情况下。但是,给出的结果为null。我认为我的linq查询是错误的。任何人都可以给我一个关于如何正确编写此查询的提示吗?非常感谢你!

2 个答案:

答案 0 :(得分:2)

Elements函数返回root的直接子元素的集合。您应该使用返回所有后代元素集合的Descendants方法。

root.Descendants("tuv").Where(e => e.Attribute("lang").Value == "en")
                       .Select(e => e.Elements("seg")).SingleOrDefault() 
                       .Where(d => d.Value == originalText).SingleOrDefault().Value

答案 1 :(得分:1)

如果你想选择第一个&#34; seg&#34;元素,做这个

var xDoc = XDocument.Parse(File.ReadAllText(@"C:\YourDirectory\sample.xml"));

var firstSeg = xDoc.Descendants("seg").First();

满足OP在评论中的要求的代码

var seg = xDoc.Descendants("tuv")
                .First(tuv => tuv.Attribute("lang").Value == "en")
                .Element("seg")
                .Value;