0

以下のようなxmlファイルがあります

<root>
 <Month name="Jan"  index="1">
      <Day index="2">
         <event> sample 1</event>
      </Day>
       <Day index="3">
         <event> sample 2 </event>
      </Day>
  </Month>

<Month name="Feb"  index="2">
      <Day index="5">
         <event> sample 3 </event>
      </Day>
       <Day index="2">
         <event> sample 4 </event>
      </Day>
  </Month>
</root>

特別な月と日のイベントを見つけるにはどうすればよいですか? たとえば、月が1で日が2の場合、「サンプル2」を取得したい

XmlDocument doc = new XmlDocument();
doc.Load("EventsXML.xml");
XmlNode even= doc.SelectSingleNode("/root/Month[@index='1'] |/root/Month/day[@index='2']");
string str=even.InnerXml.ToString();
4

2 に答える 2

2

xpath を次のように変更する必要があります。

XmlNode even= doc.SelectSingleNode("/root/Month[@index='1']/Day[@index='2']/event");

コンテンツがテキストであることがわかっているため、InnerXml ではなく InnerText を使用することもできます。または、これを考慮して xPath を変更することもできます。

XmlNode even = doc.SelectSingleNode("/root/Month[@index='1']/Day[@index='2']/event/text()");
string str = even.Value;
于 2012-03-28T14:06:15.610 に答える
2

XDocument (Linq-to-XML) の回答:

var doc = XDocument.Load(...);
var day = doc.Root
    .Descendants("Month")
    .Where(e => e.Attributes("index").Value == m)
    .Descendants("Day")
    .Where(e => e.Attributes("index").Value == d);

('m' と 'd' は簡単にするために文字列として使用)

于 2012-03-28T14:11:31.477 に答える