我正试图通过使用:
从Woocommerce的订单中提取商品元价值$data = wc_get_order_item_meta( $item, '_tmcartepo_data', true );
但是,我找不到将order_item_id作为第一个参数(使用get_items)的方法
global $woocommerce, $post, $wpdb;
$order = new WC_Order($post->ID);
$items = $order->get_items();
foreach ( $items as $item ) {
$item_id = $item['order_item_id']; //???
$data = wc_get_order_item_meta( $item_id, '_tmcartepo_data', true );
$a = $data[0]['value'];
$b = $data[1]['value'];
echo $a;
echo $b;
}
我的意思是这个订单item_id(1和2)
Order_item_id in database - Image
我该怎么做?
感谢。
答案 0 :(得分:17)
2018年更新:
- 用2种可能的案例澄清答案
- 为woocommerce 3 +
添加了兼容性
所以可能有两种情况:
1)获取产品元数据(未在订单商品元数据中设置):
您需要在WC_Order
的foreach循环中获取产品ID,并获取此产品的一些元数据,您将使用 get_post_meta()
函数(但不是 wc_get_order_item_meta()
)。
所以这是你的代码:
global $post;
$order = wc_get_order( $post->ID );
$items = $order->get_items();
foreach ( $order->get_items() => $item ) {
// Compatibility for woocommerce 3+
$product_id = version_compare( WC_VERSION, '3.0', '<' ) ? $item['product_id'] : $item->get_product_id();
// Here you get your data
$custom_field = get_post_meta( $product_id, '_tmcartepo_data', true);
// To test data output (uncomment the line below)
// print_r($custom_field);
// If it is an array of values
if( is_array( $custom_field ) ){
echo implode( '<br>', $custom_field ); // one value displayed by line
}
// just one value (a string)
else {
echo $custom_field;
}
}
2)获取订单商品元数据(自定义字段值):
global $post;
$order = wc_get_order( $post->ID );
$items = $order->get_items();
foreach ( $order->get_items() as $item_id => $item ) {
// Here you get your data
$custom_field = wc_get_order_item_meta( $item_id, '_tmcartepo_data', true );
// To test data output (uncomment the line below)
// print_r($custom_field);
// If it is an array of values
if( is_array( $custom_field ) ){
echo implode( '<br>', $custom_field ); // one value displayed by line
}
// just one value (a string)
else {
echo $custom_field;
}
}
如果自定义字段数据是数组,则可以在foreach循环中访问数据:
// Iterating in an array of keys/values
foreach( $custom_field as $key => $value ){
echo '<p>key: '.$key.' | value: '.$value.'</p>';
}
所有代码都经过测试并有效。
与订单中的数据相关的参考:
答案 1 :(得分:6)
在$order->get_items()
上执行foreach时,他们的密钥实际上是订单行ID。所以:
foreach ( $order->get_items() as $key => $item ) {
$data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
...
}
答案 2 :(得分:2)
晚会,但与TM Extra Product Options插件一样,我认为这就是你的问题的答案:
$order = wc_get_order( $post->ID );
$items = $order->get_items();
foreach( $items as $item ){
$data = unserialize($item['item_meta']['_tmcartepo_data'][0]);
$a = $data[0]['value'];
$b = $data[1]['value'];
echo $a;
echo $b;
}
在我的案例中经过测试和工作。
答案 3 :(得分:0)
使用此new WebChromeClient()
检查$ items数组/对象的所有内容。
答案 4 :(得分:0)
foreach ( $order->get_items() as $key => $item ) {
$data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
...
这个解决方案对我来说很值得,为你的meta_key更改“_tmcartepo_data”。
答案 5 :(得分:0)
从数据库获取订单商品的简单方法;
/**
* @param $order_id
*
* @return array|null|object
*/
function get_order_items( $order_id ) {
global $wpdb, $table_prefix;
$items = $wpdb->get_results( "SELECT * FROM `{$table_prefix}woocommerce_order_items` WHERE `order_id` = {$order_id}" );
$item_name = array();
foreach ( $items as $item ) {
$item_name[] = $item->order_item_name;
}
return $item_name;
}