Linq to XML - 查询不返回任何内容

时间:2010-07-27 02:37:40

标签: linq-to-xml

我有一个XML文件,当我运行LINQ查询时,在for循环中不返回任何内容。

<?xml version="1.0" encoding="utf-8"?>
<ReadOrderResponseType xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
 <Status xmlns="urn:mysite:apis">Success</Status>
 <TimeStamp xmlns="urn:mysite:apis">2010-07-25T15:26:49.1150235Z</TimeStamp>
 <StoreUrl xmlns="urn:mysite:apis">http://XYZ.COM</StoreUrl>
 <PageResponse xmlns="urn:mysite:apis">
  <Page>1</Page>
  <Size>10</Size>
  <TotalSize>18033</TotalSize>
  <HasMore>true</HasMore>
 </PageResponse>
 <OrderList OrderId="20147184" OrderNumber="20100560" xmlns="urn:mysite:apis">
  <Archived>false</Archived>
  <CreateDate>2010-07-25T01:37:04.067Z</CreateDate>
</OrderList>
</ReadOrderResponseType>

VB.NET:

Dim document As XDocument = XDocument.Parse(myOrders.xml)
                Dim query = From O In document.Root.Elements("OrderList") _
                 Select New With _
                 { _
                    .Archived= O.Element("Archived").Value, _
                    .Status = O.Element("CreateDate").Value _
                 }

                For Each Order In query
                    Console.WriteLine(Order.Archived)
                    Console.ReadLine()
                Next

它甚至没有进入for循环。我做错了什么?

1 个答案:

答案 0 :(得分:1)

您需要命名空间限定符。尝试类似:

    Dim document As XDocument = XDocument.Load("XMLFile1.xml")
    Dim apins As XNamespace = "urn:mysite:apis"
    Dim query = From O In document.Root.Elements(apins + "OrderList") _
     Select New With _
     { _
        .Archived = O.Element(apins + "Archived").Value, _
        .Status = O.Element(apins + "CreateDate").Value _
     }

    For Each Order In query
        Console.WriteLine(Order.Archived)
        Console.ReadLine()
    Next
相关问题