0

这是我的 XML 文档的前几行:

<?xml-stylesheet type="text/xsl" href="/3.0/style/exchange.xsl"?>
<ops:world-patent-data xmlns="http://www.epo.org/exchange" xmlns:ops="http://ops.epo.org" xmlns:xlink="http://www.w3.org/1999/xlink">
<ops:meta name="elapsed-time" value="83" />
<exchange-documents>
<exchange-document system="ops.epo.org" family-id="34916979" country="EP" doc-number="1726228" kind="A1">
  <bibliographic-data>
    <publication-reference>
      <document-id document-id-type="docdb">
        <country>EP</country>
        <doc-number>1726228</doc-number>`

我正在尝试使用以下代码提取文档编号:

    public class biblio
    {
        public string appNumber { get; set; }
    }

    XElement xDoc = XElement.Load(@"pathToMyXml.xml");
        XNamespace xn = "http://ops.epo.org";
        var bib = from exchange in xDoc.Descendants(xn + "exchange-document")
                  where exchange.Attribute("kind").Equals("A1")
                  select new biblio
                  {
                      appNumber = exchange.Element("doc-number").Value
                  };

但是,这不会返回任何结果。

我哪里错了?

谢谢。

4

1 回答 1

0

的命名空间doc-numberhttp://www.epo.org/exchange. 它是从根节点继承而来的。您需要在查询中指定。此外,doc-numberis 不是exchange-document. 它是一个后代。

XNamespace d = "http://www.epo.org/exchange";
var bib = from exchange in xDoc.Descendants(xn + "exchange-document")
          where (string)exchange.Attribute("kind") == "A1"
          select new biblio
          {
              appNumber = (string)exchange.Descendant(d + "doc-number")
          };

请注意,我更改exchange.Attribute("kind").Equals("A1")(string)exchange.Attribute("kind") == "A1"和。exchange.Descendant(d + "doc-number").Value(string)exchange.Descendant(d + "doc-number")

NullReferenceException如果属性或后代不存在,这会阻止s 。

于 2013-04-23T14:36:59.077 回答