2012-01-31 143 views
1

我们怎样才能获得XML节点之间的文本之间的文本越来越将XMLNode

<company> 
<data id="14" />{<data id="15" />DOCUMENT<data id="23" />pet<data id="24" />DOCUMENT<data id="25" /> 
</company> 

我需要ID 23和25(即宠物文件)

之间的数据我在xmlDoc中加载这个XML

请建议

回答

2

你可以使用LINQ:

XDocument doc = XDocument.Parse(@"<company>...</company"); 

string result = string.Join(" ", 
    doc.Root 
     .Nodes() 
     .SkipWhile(n => n.NodeType != XmlNodeType.Element || 
         (int)((XElement)n).Attribute("id") != 23) 
     .TakeWhile(n => n.NodeType != XmlNodeType.Element || 
         (int)((XElement)n).Attribute("id") != 25) 
     .OfType<XText>()); 

// result == "pet DOCUMENT" 
+0

哪部分获得文本? – DotnetSparrow 2012-01-31 18:13:13

0

Dim tDoc as XmlDocument = new XmlDocument 
Dim tNodes As XmlNodeList = Nothing 

tDoc.Load(path_to_xml_file) ' Or .LoadXml(xml_string) 
tNodes = tDoc.SelectNodes("//data") 

For Each tNode As XmlNode In tNodes 
    Select Case tNode.Attributes("id").value 
    Case 23, 24, 25 
     ' Do your processing here 
    End Select 
Next 

编辑 我误解了上面的XML。总之......我不知道具体的获取节点ID之间的文本..但你可以得到所有的文字与tDoc.SelectSingleNode("//company").InnerText

+0

我需要之间的文本这些节点。我如何获得文本? – DotnetSparrow 2012-01-31 17:39:38

0
XDocument doc = XDocument.Parse(@"<company>...</company"); 

string result = string.Join(" ", 
    doc.Root 
     .Nodes() 
     .SkipWhile(n => n.NodeType != XmlNodeType.Element || 
         (int)((XElement)n).Attribute("id") != 23) 
     .TakeWhile(n => n.NodeType != XmlNodeType.Element || 
         (int)((XElement)n).Attribute("id") != 25) 
     .OfType<XText>());