我有一个这样的XML文档:
<?xml version='1.0' encoding='UTF-8'?>
<GateDocument>
<!-- The document's features-->
<GateDocumentFeatures>
<Feature>
<Name className="java.lang.String">MimeType</Name>
<Value className="java.lang.String">text/html</Value>
</Feature>
</GateDocumentFeatures>
<!-- The document content area with serialized nodes -->
<TextWithNodes><Node id="0" />astralis<Node id="8" /> <Node id="9" />ltd<Node id="12" />
<Node id="14" />{<Node id="15" />DOCUMENT<Node id="23" />}<Node id="24" /> <Node id="25" />{<Node id="26" />TYPE<Node id="30" />}<Node id="31" />EX-<Node id="34" />10<Node id="36" />.<Node id="37" />12<Node id="39" /> <Node id="40" />{<Node id="41" />SEQUENCE<Node id="49" />}<Node id="50" />3<Node id="51" /> <Node id="52" />{<Node id="53" />FILENAME<Node id="61" />}<Node id="62" />e<Node id="63" />300201<Node id="69" />_<Node id="70" />ex<Node id="72" />10<Node id="74" />-<Node id="75" />12<Node id="77" />.<Node id="78" />txt<Node id="81" /> <Node id="82" />{<Node id="83" />DESCRIPTION<Node id="94" />}<Node id="95" />
</TextWithNodes>
<Annotations>
.
.
.
.
.
</Annotations>
<Annotations Name="Original markups">
.
.
.
.
</Annotations>
</GateDocument>
我使用vb.net/asp.net在XMLDocument中加载了这个XML。我需要ID为&gt;的节点之间的数据。 16和Id&lt; 30是“} {TYPe}”请注意,它不是属性的值。它是节点之间的数据。我创建了以下代码,但速度非常慢。
Dim sb As New StringBuilder()
Dim document As New XPathDocument(System.Web.HttpContext.Current.Server.MapPath("~/App_Data/gate_xml_output.xml"))
Dim navigator As XPathNavigator = document.CreateNavigator()
Dim iterator As XPathNodeIterator = navigator.Select("//TextWithNodes/node()[preceding-sibling::Node[@id=" & startNode & "] and following-sibling::Node[@id=" & endNode & "]]")
While iterator.MoveNext()
sb.Append(iterator.Current.Value & " ")
End While
可能需要修改以下代码:
XDocument doc = XDocument.Parse(@"<TextWithNodes>...</TextWithNodes");
string result = string.Join(" ",
doc.Root
.Nodes()
.SkipWhile(n => n.NodeType != XmlNodeType.Element ||
(int)((XElement)n).Attribute("id") != 16)
.TakeWhile(n => n.NodeType != XmlNodeType.Element ||
(int)((XElement)n).Attribute("id") != 30)
.OfType<XText>());
// result == "pet DOCUMENT"
我需要提供给XDocument.Parse。
请建议。
答案 0 :(得分:0)
我使用的范围是15到30
XDocument xml = XDocument.Load("file.xml");
var firstElement = xml.Descendants().Where(x => x.Name == "Node" && x.Attribute("id").Value=="15").FirstOrDefault();
var lastElement = xml.Descendants().Where(x => x.Name == "Node" && x.Attribute("id").Value == "30").FirstOrDefault();
var response = firstElement.NodesAfterSelf().Where(x => lastElement.NodesBeforeSelf().Contains(x));
返回元素。您可以使用ToString()
获取内容答案 1 :(得分:0)
我认为您所说的是如何使用XDocument.Parse
因为你的XML看起来是外部文件,所以最好使用
XDocument doc = XDocument.Load("myXmlFile.xml");
然后继续使用LINQ to XML作为样本。抱歉,如果我误解了