简体   繁体   English

解析XML文档

[英]Parse XML document

I am trying to parse a remote XML document (from Amazon AWS): 我正在尝试解析远程XML文档(从Amazon AWS):

<ItemLookupResponse xmlns="http://webservices.amazon.com/AWSECommerceService/2009-03-31">
      <OperationRequest>
        <RequestId>011d32c5-4fab-4c7d-8785-ac48b9bda6da</RequestId>
        <Arguments>
          <Argument Name="Condition" Value="New"></Argument>
          <Argument Name="Operation" Value="ItemLookup"></Argument>
          <Argument Name="Service" Value="AWSECommerceService"></Argument>
          <Argument Name="Signature" Value="73l8oLJhITTsWtHxsdrS3BMKsdf01n37PE8u/XCbsJM="></Argument>
          <Argument Name="MerchantId" Value="Amazon"></Argument>
          <Argument Name="Version" Value="2009-03-31"></Argument>
          <Argument Name="ItemId" Value="603084260089"></Argument>
          <Argument Name="IdType" Value="UPC"></Argument>
          <Argument Name="AWSAccessKeyId" Value="[myAccessKey]"></Argument>
          <Argument Name="Timestamp" Value="2010-06-14T15:03:27Z"></Argument>
          <Argument Name="ResponseGroup" Value="OfferSummary,ItemAttributes"></Argument>
          <Argument Name="SearchIndex" Value="All"></Argument>
        </Arguments>
        <RequestProcessingTime>0.0318510000000000</RequestProcessingTime>
      </OperationRequest>
      <Items>
        <Request>
          <IsValid>True</IsValid>
          <ItemLookupRequest>
            <Condition>New</Condition>
            <DeliveryMethod>Ship</DeliveryMethod>
            <IdType>UPC</IdType>
            <MerchantId>Amazon</MerchantId>
            <OfferPage>1</OfferPage>
            <ItemId>603084260089</ItemId>
            <ResponseGroup>OfferSummary</ResponseGroup>
            <ResponseGroup>ItemAttributes</ResponseGroup>
            <ReviewPage>1</ReviewPage>
            <ReviewSort>-SubmissionDate</ReviewSort>
            <SearchIndex>All</SearchIndex>
            <VariationPage>All</VariationPage>
          </ItemLookupRequest>
        </Request>
        <Item>
          <ASIN>B0000UTUNI</ASIN>
          <DetailPageURL>http://www.amazon.com/Garnier-Fructis-Fortifying-Conditioner-Minute/dp/B0000UTUNI%3FSubscriptionId%3DAKIAIYPTKHCWTRWWPWBQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D165953%26creativeASIN%3DB0000UTUNI</DetailPageURL>
          <ItemLinks>
            <ItemLink>
              <Description>Technical Details</Description>
              <URL>http://www.amazon.com/Garnier-Fructis-Fortifying-Conditioner-Minute/dp/tech-data/B0000UTUNI%3FSubscriptionId%3DAKIAIYPTKHCWTRWWPWBQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D386001%26creativeASIN%3DB0000UTUNI</URL>
            </ItemLink>
            <ItemLink>
              <Description>Add To Baby Registry</Description>
              <URL>http://www.amazon.com/gp/registry/baby/add-item.html%3Fasin.0%3DB0000UTUNI%26SubscriptionId%3DAKIAIYPTKHCWTRWWPWBQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D386001%26creativeASIN%3DB0000UTUNI</URL>
            </ItemLink>
            <ItemLink>
              <Description>Add To Wedding Registry</Description>
              <URL>http://www.amazon.com/gp/registry/wedding/add-item.html%3Fasin.0%3DB0000UTUNI%26SubscriptionId%3DAKIAIYPTKHCWTRWWPWBQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D386001%26creativeASIN%3DB0000UTUNI</URL>
            </ItemLink>
            <ItemLink>
              <Description>Add To Wishlist</Description>
              <URL>http://www.amazon.com/gp/registry/wishlist/add-item.html%3Fasin.0%3DB0000UTUNI%26SubscriptionId%3DAKIAIYPTKHCWTRWWPWBQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D386001%26creativeASIN%3DB0000UTUNI</URL>
            </ItemLink>
            <ItemLink>
              <Description>Tell A Friend</Description>
              <URL>http://www.amazon.com/gp/pdp/taf/B0000UTUNI%3FSubscriptionId%3DAKIAIYPTKHCWTRWWPWBQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D386001%26creativeASIN%3DB0000UTUNI</URL>
            </ItemLink>
            <ItemLink>
              <Description>All Customer Reviews</Description>
              <URL>http://www.amazon.com/review/product/B0000UTUNI%3FSubscriptionId%3DAKIAIYPTKHCWTRWWPWBQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D386001%26creativeASIN%3DB0000UTUNI</URL>
            </ItemLink>
            <ItemLink>
              <Description>All Offers</Description>
              <URL>http://www.amazon.com/gp/offer-listing/B0000UTUNI%3FSubscriptionId%3DAKIAIYPTKHCWTRWWPWBQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D386001%26creativeASIN%3DB0000UTUNI</URL>
            </ItemLink>
          </ItemLinks>
          <ItemAttributes>
            <Binding>Health and Beauty</Binding>
            <Brand>Garnier</Brand>
            <EAN>0603084260089</EAN>
            <Feature>Helps restore strength and shine</Feature>
            <Feature>Penetrates deep to nourish, repair and rejuvenate</Feature>
            <Feature>Makes hair softer and more manageable without weighing it down</Feature>
            <ItemDimensions>
              <Weight Units="hundredths-pounds">40</Weight>
            </ItemDimensions>
            <Label>Garnier</Label>
            <ListPrice>
              <Amount>419</Amount>
              <CurrencyCode>USD</CurrencyCode>
              <FormattedPrice>$4.19</FormattedPrice>
            </ListPrice>
            <Manufacturer>Garnier</Manufacturer>
            <NumberOfItems>1</NumberOfItems>
            <ProductGroup>Health and Beauty</ProductGroup>
            <ProductTypeName>ABIS_DRUGSTORE</ProductTypeName>
            <Publisher>Garnier</Publisher>
            <Size>5.0 oz</Size>
            <Studio>Garnier</Studio>
            <Title>Garnier Fructis Fortifying Fortifying Deep Conditioner, 3 Minute Masque - 5 oz</Title>
            <UPC>603084260089</UPC>
          </ItemAttributes>
          <OfferSummary>
            <LowestNewPrice>
              <Amount>229</Amount>
              <CurrencyCode>USD</CurrencyCode>
              <FormattedPrice>$2.29</FormattedPrice>
            </LowestNewPrice>
            <TotalNew>7</TotalNew>
            <TotalUsed>0</TotalUsed>
            <TotalCollectible>0</TotalCollectible>
            <TotalRefurbished>0</TotalRefurbished>
          </OfferSummary>
        </Item>
      </Items>
    </ItemLookupResponse>

I am trying to extract data from the XML stream using XPathDocument, but with no luck: 我试图使用XPathDocument从XML流中提取数据,但是没有运气:

WebRequest request = HttpWebRequest.Create(url);
        WebResponse response = request.GetResponse();
        //XmlDocument doc = new XmlDocument();

        XPathDocument Doc = new XPathDocument(response.GetResponseStream());
        XPathNavigator nav = Doc.CreateNavigator();
        XPathNodeIterator ListPrice = nav.Select("/ItemLookupResponse/Items/Item/ItemAttributes/ListPrice");
        foreach (XPathNavigator node in ListPrice)
        {
            Response.Write(node.GetAttribute("Amount", NAMESPACE));
        }

What am I missing? 我想念什么? Thanks in advance!! 提前致谢!!

EDIT I am using .net 3.5 编辑我正在使用.net 3.5

Amount is not an attribute, it's a child element. 金额不是属性,而是子元素。

The according xpath-query would be /ItemLookupResponse/Items/Item/ItemAttributes/ListPrice/Amount . 根据xpath查询将是/ItemLookupResponse/Items/Item/ItemAttributes/ListPrice/Amount

XPathNodeIterator ListPrice = nav.Select("/ItemLookupResponse/Items/Item/ItemAttributes/ListPrice/Amount");

Response.Write(ListPrice.Value);

What version of the .Net framework are you using? 您正在使用哪个版本的.Net框架? Is LINQ available to you? LINQ对您可用吗? If it is I would use that to pull out the values as it is a little nicer to work with. 如果是的话,我会用它来提取值,因为使用起来会更好一些。 For a really nice example of LINQ have a look here: 对于LINQ的一个非常好的示例,请看这里:

http://weblogs.asp.net/scottgu/archive/2007/08/07/using-linq-to-xml-and-how-to-build-a-custom-rss-feed-reader-with-it.aspx http://weblogs.asp.net/scottgu/archive/2007/08/07/using-linq-to-xml-and-how-to-build-a-custom-rss-feed-reader-with-it。 aspx

You're not paying attention to the XML namespace(s) in the XML document (and neither are the other answers provided): 您无需关注XML文档中的XML名称空间(也没有提供其他答案):

<ItemLookupResponse 
     xmlns="http://webservices.amazon.com/AWSECommerceService/2009-03-31">

You need to take that into account! 您需要考虑到这一点!

XPathDocument Doc = new XPathDocument(@"D:\amazon.xml");

XPathNavigator nav = Doc.CreateNavigator();

// add a XML namespace manager - pick any prefix you want        
XmlNamespaceManager mngr = new XmlNamespaceManager(nav.NameTable);
mngr.AddNamespace("az", "http://webservices.amazon.com/AWSECommerceService/2009-03-31");

// use that XML namespace prefix to select
var ListPrice = nav.Select("/az:ItemLookupResponse/az:Items/az:Item/az:ItemAttributes/az:ListPrice", mngr);

UPDATE: if you want to explore the child nodes below your ListPrice node, you can do something like this: 更新:如果要浏览ListPrice节点下面的ListPrice节点,可以执行以下操作:

var curr = ListPrice.Current;

if(ListPrice.MoveNext())
{
    var lpc = ListPrice.Current;

    if(lpc.MoveToFirstChild())
    {
       var node = lpc.Name + "/" + lpc.Value;

       while(lpc.MoveToNext())
       {
           node = lpc.Name + "/" + lpc.Value;
       }
    }
}

to iterate through all child nodes under <ListPrice> and get their name and value. 遍历<ListPrice>下的所有子节点并获取其名称和值。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM