Использование XPath в C # для получения всех значений узлов из XML - PullRequest
2 голосов
/ 10 мая 2011

У меня есть XML ниже:

<tcm:Component ID="tcm:481-636667" IsEditable="false" xmlns:tcm="http://www.tridion.com/ContentManager/5.0" xmlns:xlink="http://www.w3.org/1999/xlink">
  <tcm:Context>
    <tcm:Publication xlink:type="simple" xlink:title="07 Internal Test Publication" xlink:href="tcm:0-481-1"/>
    <tcm:OrganizationalItem xlink:type="simple" xlink:title="System Resources" xlink:href="tcm:481-92640-2"/>
  </tcm:Context> 
  <tcm:Data>
    <tcm:Title>IBE - Skywards</tcm:Title>
    <tcm:Type>Normal</tcm:Type>
    <tcm:Schema xlink:type="simple" xlink:title="Resources" xlink:href="tcm:481-190471-8"/>
    <tcm:Content>
      <Resources xmlns="http://www.sdltridion.com/tridion/schemas">
        <Text>
          <Key>SKYRL_MBD</Key>
          <Value>Miles Breakdown</Value>
        </Text>
        <Text>
          <Key>ltSR_MB.Text</Key>
          <Value>View Miles Breakdown</Value>
        </Text>
        <Text>
          <Key>ltSR_HMB.Text</Key>
          <Value>Hide Miles Breakdown</Value>
        </Text>
        <Text>
          <Key>SKYRL_MBD_LK</Key>
          <Value>Miles Breakdown</Value>
        </Text>    
      </Resources>
    </tcm:Content>
    <tcm:Metadata>
      <Metadata xmlns="http://www.sdltridion.com/tridion/schemas">
        <Language>
          <Language>English</Language>
        </Language>
      </Metadata>
    </tcm:Metadata>  
  </tcm:Data>
</tcm:Component>

Теперь я хочу написать метод на C #, который будет принимать этот XML в качестве входного и возвращать все данные «Key» и «Value» в List.

Пожалуйста, предложите.

Ответы [ 3 ]

5 голосов
/ 10 мая 2011

Сначала объявите списки для хранения значений:

using System.Collections.Generic;

List<string> keysList = new List<string>();
List<string> valuesList = new List<string>();

Тогда:

using System.Xml; // System.Xml.dll

XmlDocument doc = new XmlDocument();
doc.LoadXml(xml); // Load(file)

var ns = new XmlNamespaceManager(doc.NameTable);
ns.AddNamespace("tcm", "http://www.tridion.com/ContentManager/5.0");
ns.AddNamespace("xlink", "http://www.w3.org/1999/xlink");

foreach (XmlNode node in doc.SelectNodes("//*[local-name()=\"Key\"]"))
{
    keysList.Add(node.InnerText);
}
foreach (XmlNode node in doc.SelectNodes("//*[local-name()=\"Value\"]"))
{
    valuesList.Add(node.InnerText);
}   

если вам не нужен XML DOM, только XPath для оценки:

using System.Xml.XPath; // System.Xml.dll

XPathDocument doc = null;
using (TextReader reader = new StringReader(xml))
{
    doc = new XPathDocument(reader); // specify just path to file if you have such one
}
XPathNavigator nav = doc.CreateNavigator();
foreach (XPathNavigator node in (XPathNodeIterator)nav.Evaluate("//*[local-name()=\"Key\"]"))
{
     keysList.Add(node.Value);
}
foreach (XPathNavigator node in (XPathNodeIterator)nav.Evaluate("//*[local-name()=\"Value\"]"))
{
     valuesList.Add(node.Value);
}
3 голосов
/ 10 мая 2011

Используйте XElement или XDocument (Linq2Xml)

XElement xml = XElement.Parse("inputxml");
var keys = xml.Descendants("Key");

OP говорит, что он использует .Net 2.0.Тогда это не сработает!

0 голосов
/ 10 мая 2011

Посмотрите на классы в пространстве имен System.Xml.Linq. Если вы начинаете с XDocument, вы можете загрузить свой XML и просто запросить содержимое с помощью Linq.

...