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");

您也可以使用 InnerText 而不是 InnerXml,因为您知道内容是文本,或者您可以修改 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 回答