1

我正在构建的应用程序的一部分需要从 XML 文档生成 robots.txt 文件。

我有这样的 XML:

<root>
  <Robots>
    <UserAgents>
      <UserAgent>*</UserAgent>
      <Disallow>
        <Item>/wibble/</Item>
        <Item>/wobble/</Item>
      </Disallow>
    </UserAgents>
    <UserAgents>
      <UserAgent>Google</UserAgent>
      <Disallow>
        <Item>/</Item>
      </Disallow>
    </UserAgents>
  </Robots>
</root>

如何选择 UserAgent =“*”的“项目”?

换句话说,我只想在父节点等于某个值时选择子节点。父节点中的值将是唯一的。

我在 ASP.net 中使用 C#。

4

2 回答 2

4

听起来你想要这样的东西:

var query = from agent in doc.Descendants("UserAgent")
            where (string) agent == "*"
            from item in agent.Parent.Elements("Disallow").Elements("Item") 
            select item;

请注意,第二个from仅用于展平结果,因此它不是序列序列。

或者:

var query = doc.Descendants("UserAgent")
               .Where(agent => (string) agent == "*")
               .SelectMany(agent => agent.Parent.Elements("Disallow")
                                                .Elements("Item"));

或者通过将选中的“顶部”节点更改为UserAgents,可以避免父步骤:

var query = doc.Descendants("UserAgents")
               .Where(agents => (string) agents.Element("UserAgent") == "*")
               .SelectMany(agent => agent.Elements("Disallow").Elements("Item"));

请注意,如果您UserAgent在单个元素下有多个元素,则不会给出相同的结果UserAgents

(顺便说一句,你能改变 XML 模式吗?看起来你应该能够简化这个......)

于 2012-05-01T13:50:31.653 回答
1
var query = from x in doc.Root.Element("Robots").Elements("UserAgents")
            where (string)x.Element("UserAgent") == "*"
            from y in x.Element("Disallow").Elements("Item")
            select y;
于 2012-05-01T13:50:07.563 回答