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

时间:2012-02-03 12:17:04

标签: c# asp.net xml vb.net

我有一个这样的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。

请建议。

2 个答案:

答案 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作为样本。抱歉,如果我误解了