使用asp.net Vb.net从XML中获取数据

本文关键字:net 获取 XML 数据 asp Vb 使用 | 更新日期: 2023-09-27 18:22:17

我有一个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>16和id<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.提供什么

请提出建议。

使用asp.net Vb.net从XML中获取数据

我使用的范围为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()

获取内容

我想你说的是如何使用XDocument.Parse

因为从外观上看,XML是在外部文件中的,所以最好使用

XDocument doc = XDocument.Load("myXmlFile.xml");

然后使用LINQ to XML作为示例进行操作。如果我误解了

,深表歉意