获取 woocommerce 3 中订单项的元数据

2022-08-30 21:02:54

如何获取产品woocommerce的元数据?我有字段自定义我的产品,我需要获取此数据。

{"ID":151,
 "ORDER_ID":251,
 "NAME":"car",
 "PRODUCT_ID":87,
 "VARIATION_ID":0,
 "QUANTITY":1,
 "TAX_CLASS":"",
 "SUBTOTAL":"3",
 "SUBTOTAL_TAX":"0",
 "TOTAL":"3",
 "TOTAL_TAX":"0",
 "TAXES":{"TOTAL":[],
          "SUBTOTAL":[]},
 "META_DATA":[{"ID":1433,
               "KEY":"my_car",
               "VALUE":"red"}]}

但总是结果是一样的,我无法访问字段。该字段和我有权访问。meta_dataIDname

我使用和,但是当我尝试访问字段时,它会给我这个错误:get_data()get_item()get_data()meta_data

 UNCAUGHT ERROR: CANNOT USE OBJECT OF TYPE WC_DATETIME AS ARRAY IN  

如果使用 ,则该值为空,因为受保护。get_item()meta_data

如何获取这些值?


答案 1

请尝试以下操作:

// Get the $order object from an ID (if needed only)
$order = wc_get_order( $order_id);

// Loop through order line items
foreach( $order->get_items() as $item ){
    // get order item data (in an unprotected array)
    $item_data = $item->get_data();
    
    // get order item meta data (in an unprotected array)
    $item_meta_data = $item->get_meta_data();
    
    // get only All item meta data even hidden (in an unprotected array)
    $formatted_meta_data = $item->get_formatted_meta_data( '_', true );

    // Display the raw outputs (for testing)
    echo '<pre>' . print_r($item_meta_data, true) . '</pre>';
    echo '<pre>' . print_r($formatted_meta_data, true) . '</pre>';
}

相关:


答案 2
/* Get Order Meta in Array[] format at thank you page - woocommerce */

add_action( 'woocommerce_thankyou', 'get_order_meta_at_thankyoupage', 20, 1);
function get_order_meta_at_thankyoupage( $order_id ){
  $orderr = wc_get_order($order_id);
 echo '<pre>';
 print_r($orderr);
 echo '</pre>';
    
}

推荐