解析XML节点会导致列出所有相同的项目

时间:2016-02-24 17:03:56

标签: c# xml list xmlnode ebay-api

我在以前的项目中遇到过这个问题,但是从来没有理解为什么会这样,并且会欣赏这方面的任何信息,以及如何始终如一地避免这个问题。

我有来自eBay的XML格式的库存报告。我正在将SKU节点解析为一个列表,以确定我们在库存中没有在易趣上列出的产品。

下面的代码段会生成一个列表,所有相同的SKU。我已经验证XmlNodeList填充了大约8000个唯一字符串。我相信错误与引擎盖指针/引用类问题有关。就像我使用临时内存空间来存储XmlNode对象而returnList指向那个内存位置,而不是做一个memcpy类型的操作来传输将字符串放入列表中。

任何指针都会非常感激。

示例XML:

<?xml version="1.0" encoding="utf-8"?>
<BulkDataExchangeResponses xmlns="urn:ebay:apis:eBLBaseComponents">
    <ActiveInventoryReport>
        <SKUDetails>
            <SKU>FAKE0012</SKU>
            <Price currencyID="USD">5.99</Price>
            <Quantity>12</Quantity>
            <ItemID>123456789123</ItemID>
        </SKUDetails>               
    </ActiveInventoryReport>
</BulkDataExchangeResponses>

代码清单:

private List<string> getListingsFromXML(string fileName)
    {
        List<string> returnList = new List<string>();

        XmlDocument doc = new XmlDocument();
        XmlNamespaceManager ns = new XmlNamespaceManager(doc.NameTable);
        ns.AddNamespace("ebay", "urn:ebay:apis:eBLBaseComponents");
        doc.Load(fileName);
        XmlElement root = doc.DocumentElement;

        XmlNode node = root.SelectSingleNode("//ebay:ActiveInventoryReport",ns);

        XmlNodeList skus = node.SelectNodes("//ebay:SKUDetails",ns);

        foreach (XmlNode sku in skus)
        {
            XmlNode tempNode = sku.SelectSingleNode("//ebay:SKU",ns);
            if (tempNode != null)
            {
                //tempNode.InnerText is always the first SKU in skus
                //sku iterates through list as expected.
                returnList.Add(tempNode.InnerText.Trim());
            }
        }

        return returnList;
    }

1 个答案:

答案 0 :(得分:0)

我发现了我的问题。 //在XML文档中创建绝对路径,以便它每次都以某种方式检索第一个节点。删除它修复了问题。更正后的代码:

private List<string> getListingsFromXML(string fileName)
    {
        List<string> returnList = new List<string>();

        XmlDocument doc = new XmlDocument();
        XmlNamespaceManager ns = new XmlNamespaceManager(doc.NameTable);
        ns.AddNamespace("ebay", "urn:ebay:apis:eBLBaseComponents");
        doc.Load(fileName);
        XmlElement root = doc.DocumentElement;

        XmlNode node = root.SelectSingleNode("//ebay:ActiveInventoryReport", ns);

        XmlNodeList skus = node.SelectNodes("//ebay:SKUDetails", ns);

        foreach (XmlNode sku in skus)
        {
            XmlNode tempNode = sku.SelectSingleNode("ebay:SKU", ns);
            if (tempNode != null)
            {
                returnList.Add(tempNode.InnerText.Trim());
            }
        }

        return returnList;
    }

我在提交答案后看到了@wero的评论。回答后,我很乐意接受。