php - WooCommerce:获取所有产品变体的 SKU
问题描述
我有一个产品列表,应该在它自己的行中显示变化。到目前为止,该代码工作正常。
但我不知道如何显示变体的 SKU。
这是我当前的代码:
$args = [
'status' => array('publish', 'draft'),
'orderby' => 'name',
'order' => 'ASC',
'limit' => -1,
];
$vendor_products = wc_get_products($args);
$list_array = array();
foreach ($vendor_products as $key => $product) {
if ($product->get_type() == "variable") {
foreach ($product->get_variation_attributes() as $variations) {
foreach ($variations as $variation) {
$list_array[] = array(
'SKU' => $product->get_sku(),
'Name' => $product->get_title() . " - " . $variation,
);
}
}
} else {
$list_array[] = array(
'SKU' => $product->get_sku(),
'Name' => $product->get_title(),
);
}
}
return $list_array;
我尝试显示产品属性,还尝试获取变体的 ID。什么都不适合我?!
是否没有简单的方法来获取变体 SKU?
解决方案
您应该更好地使用WC_Product_Variable
get_children()
以下方法:
$args = [
'status' => array('publish', 'draft'),
'orderby' => 'name',
'order' => 'ASC',
'limit' => -1,
];
$vendor_products = wc_get_products($args);
$list_array = array();
foreach ($vendor_products as $key => $product) {
if ( $product->is_type( "variable" ) ) {
foreach ( $product->get_children( false ) as $child_id ) {
// get an instance of the WC_Variation_product Object
$variation = wc_get_product( $child_id );
if ( ! $variation || ! $variation->exists() ) {
continue;
}
$list_array[] = array(
'SKU' => $variation->get_sku(),
'Name' => $product->get_name() . " - " . $child_id,
);
}
} else {
$list_array[] = array(
'SKU' => $product->get_sku(),
'Name' => $product->get_name(),
);
}
}
return $list_array;
甚至是其他一些可用的方法,例如(在查看其源代码时使用方法)。它应该更好地工作......get_available_variations()
get_children()
针对具有不同其他帖子状态的可变产品的产品变体而不是“ publish"
。
在这种情况下,您应该使用自定义 WP_Query 替换 get_children() 方法,该方法将处理其他帖子状态,如下所示:
$statuses = array('publish', 'draft');
// Args on the main query for WC_Product_Query
$args = [
'status' => $statuses,
'orderby' => 'name',
'order' => 'ASC',
'limit' => -1,
];
$vendor_products = wc_get_products($args);
$list_array = array();
foreach ($vendor_products as $key => $product) {
if ($product->get_type() == "variable") {
// Args on product variations query for a variable product using a WP_Query
$args2 = array(
'post_parent' => $product->get_id(),
'post_type' => 'product_variation',
'orderby' => array( 'menu_order' => 'ASC', 'ID' => 'ASC' ),
'fields' => 'ids',
'post_status' => $statuses,
'numberposts' => -1,
);
foreach ( get_posts( $args2 ) as $child_id ) {
// get an instance of the WC_Variation_product Object
$variation = wc_get_product( $child_id );
if ( ! $variation || ! $variation->exists() ) {
continue;
}
$list_array[] = array(
'SKU' => $variation->get_sku(),
'Name' => $product->get_name() . " - " . $child_id,
);
}
} else {
$list_array[] = array(
'SKU' => $product->get_sku(),
'Name' => $product->get_name(),
);
}
}
return $list_array;
这次您将获得可变产品的所有产品变体。
推荐阅读
- python - Python - 字典列表到 redis 列表
- python - 使用网络抓取从 Twitter 下载搜索结果
- javascript - 如何在下面的方法中用 log.error 替换 printStackTrace
- python - Pyinstaller 无法执行脚本 pyi_rth_pkgres
- machine-learning - LUIS 中匹配冲突的实体
- kubernetes - PersistentVolumeClaim 已删除,但我可以在 kube-controller-manager 中看到 pvc 配置失败的日志
- python - Py:函数之间传递实例的问题
- sql-server - 仅使用开始时间创建间隔
- regex - 用正则表达式替换
- excel - Power BI - 我们可以从一些 EXCEL 文件中加载 ROLES 及其关联的 DAX 过滤器表达式吗?