Woocommerce.NET + C#:从SKU获取产品ID

时间:2020-05-12 09:14:11

标签: c# woocommerce-rest-api

我正在使用C#和Woocommerce.NET包装器制作一个小型应用程序。 我想编辑一个产品,但是我没有产品的ID,只有SKU。

从SKU编号获取产品ID的最简单方法是什么?

我已经尝试过了:

RestAPI rest = new RestAPI(url, key, secret); 
WCObject wc = new WCObject(rest);  

var products = wc.Product.GetAll().GetAwaiter().GetResult();

products.ForEach(p => if p.sku = productSKU)
    {
        var productIDfromSKU = p.id;
    }

编辑:我已经更改了代码,可以转换为int,并且现在可以使用!

foreach (var p in products)
     {
      if (p.sku == SKU)
           {
            IDfromSKU = Convert.ToInt32(p.id);

             };
       };

但是问题是,我只能得到10种产品的清单-并非全部。 有这个设置吗? 我的问题仍然存在-还有更直接的方法吗?

编辑2:

我已经实现了您的答案,代码可以运行,但是速度非常慢。 大约5000种产品需要2-3分钟。

我该怎么做才能加快速度?

编辑3:

对不起,还没有做足够的测试-第二个答案很好!

string SKU = "***wanted SKU***";
List<Product> products  = new List<Product>();
Dictionary<string, string> pDic = new Dictionary<string, string>();
pDic.Add("sku", SKU);

int productIDfromSKU = 0;
string productNamefromSKU  = "";
products  = await wc.Product.GetAll(pDic);
if (products.Count > 0)
{
    productIDfromSKU = Convert.ToInt32(products[0].id);
    productNfromSKU = products[0].name;
}

考虑我的问题已解决!

谢谢大家!

2 个答案:

答案 0 :(得分:0)

        RestAPI rest = new RestAPI(url, key, secret); 
        WCObject wc = new WCObject(rest);              

        List<Product> products = new List<Product>();
        Dictionary<string, string> dic1 = new Dictionary<string, string>();
        dic1.Add("per_page", "100");
        int pageNumber1 = 1;
        dic1.Add("page", pageNumber1.ToString());

        bool endWhile1 = false;
        while (!endWhile1)
        {
            var productsTemp = await wc.Product.GetAll(dic1);
            if (productsTemp.Count > 0)
            {
                products.AddRange(productsTemp);
                pageNumber1++;
                dic1["page"] = pageNumber1.ToString();
            }
            else
            {
                endWhile1 = true;
            }
        }

        foreach (Product p in products)
        {
           if (p.sku == SKU)
           {
               IDfromSKU = Convert.ToInt32(p.id);
               break;
           };
        }

答案 1 :(得分:0)

        RestAPI rest = new RestAPI(url, key, secret); 
        WCObject wc = new WCObject(rest);

        string SKU = "***wanted SKU***";
        List<Product> products  = new List<Product>();
        Dictionary<string, string> pDic = new Dictionary<string, string>();
        pDic.Add("sku", SKU);

        int productIDfromSKU = 0;
        string productNamefromSKU  = "";
        products  = await wc.Product.GetAll(pDic);
        if (products.Count > 0)
        {
            productIDfromSKU = Convert.ToInt32(products[0].id);
            productNfromSKU = products[0].name;
        }