如何从woo-commerce获得所有产品?

问题描述 投票:2回答:2

我已经设置了Woo-Commerce,它有1000多种产品。使用Woocommerce rest api php库我试图获得所有产品。

但它给了我10个产品。如果我使用过滤器[限制],它给了我大约400个不超过这个的产品。

$res = $wc_api->get_products(array( 'filter[limit]' => 400 ) );

任何人都可以说我如何从woocommerce获得所有产品?

wordpress rest woocommerce product woocommerce-rest-api
2个回答
1
投票

有关最新版本的WC API,请使用

$products = $client->products->get( '', ['filter[limit]' => -1] );

如果它不起作用,请尝试使用posts_per_page替换限制,如下所示:

'filter[posts_per_page]'=>-1

根据您的服务器规格和产品总数,此类型的查询可能需要大量内存,因此如果您收到任何错误或查询未完成,请确保php.ini中的内存限制足够高。


0
投票

这不是最新的API端点:

/wc-api/v3/products?filter[limit]=

您必须每页获取页面才能获得所有产品:

$page = 1;
$products = [];
$all_products = [];
do{
  try {
    $products = $wc->get('products',array('per_page' => 100, 'page' => $page));
  }catch(HttpClientException $e){
    die("Can't get products: $e");
  }
  $all_products = array_merge($all_products,$products);
  $page++;
} while (count($products) > 0);

Source

© www.soinside.com 2019 - 2024. All rights reserved.