php - 如何在 wordpress/woocommerce 中获取所有订单详细信息?

标签 php wordpress woocommerce wordpress-theming

这个问题在这里已经有了答案:





How to get WooCommerce order details

(5 个回答)


3年前关闭。




我正在使用 woo-commerce 并试图从数据库中获取所有订单详细信息。我是新手,无法实现。我已经创建了 order_details.php我可以在其中获取所有订单数据的模板。

谁能帮我吗?

最佳答案

自 Woocommerce 大型更新 3.0+ 以来,事情发生了很大变化:

  • WC_Order 属性不能像以前一样直接访问,并且会抛出一些错误。
  • 新品 WC_订单 WC_Abstract_Order 现在需要 getter 和 setter 方法。
  • 订单项目有一些新类:
  • WC_Order_Item 类。
  • WC_Order_Item_Product 类。

  • 因此,在 foreach 循环中也不能像以前那样访问 Order items 属性,您必须使用 this specific getter and setter methods反而
    // Get an instance of the WC_Order object (same as before)
    $order = wc_get_order( $order_id );
    
    // Get the order ID
    $order_id = $order->get_id();
    
    // Get the custumer ID
    $order_id = $order->get_user_id();
    

    获取和访问订单数据属性(在值数组中):
    $order = wc_get_order( $order_id );
    
    $order_data = $order->get_data(); // The Order data
    
    $order_id = $order_data['id'];
    $order_parent_id = $order_data['parent_id'];
    $order_status = $order_data['status'];
    $order_currency = $order_data['currency'];
    $order_version = $order_data['version'];
    $order_payment_method = $order_data['payment_method'];
    $order_payment_method_title = $order_data['payment_method_title'];
    $order_payment_method = $order_data['payment_method'];
    $order_payment_method = $order_data['payment_method'];
    
    ## Creation and modified WC_DateTime Object date string ##
    
    // Using a formated date ( with php date() function as method)
    $order_date_created = $order_data['date_created']->date('Y-m-d H:i:s');
    $order_date_modified = $order_data['date_modified']->date('Y-m-d H:i:s');
    
    // Using a timestamp ( with php getTimestamp() function as method)
    $order_timestamp_created = $order_data['date_created']->getTimestamp();
    $order_timestamp_modified = $order_data['date_modified']->getTimestamp();
    
    
    $order_discount_total = $order_data['discount_total'];
    $order_discount_tax = $order_data['discount_tax'];
    $order_shipping_total = $order_data['shipping_total'];
    $order_shipping_tax = $order_data['shipping_tax'];
    $order_total = $order_data['cart_tax'];
    $order_total_tax = $order_data['total_tax'];
    $order_customer_id = $order_data['customer_id']; // ... and so on
    
    ## BILLING INFORMATION:
    
    $order_billing_first_name = $order_data['billing']['first_name'];
    $order_billing_last_name = $order_data['billing']['last_name'];
    $order_billing_company = $order_data['billing']['company'];
    $order_billing_address_1 = $order_data['billing']['address_1'];
    $order_billing_address_2 = $order_data['billing']['address_2'];
    $order_billing_city = $order_data['billing']['city'];
    $order_billing_state = $order_data['billing']['state'];
    $order_billing_postcode = $order_data['billing']['postcode'];
    $order_billing_country = $order_data['billing']['country'];
    $order_billing_email = $order_data['billing']['email'];
    $order_billing_phone = $order_data['billing']['phone'];
    
    ## SHIPPING INFORMATION:
    
    $order_shipping_first_name = $order_data['shipping']['first_name'];
    $order_shipping_last_name = $order_data['shipping']['last_name'];
    $order_shipping_company = $order_data['shipping']['company'];
    $order_shipping_address_1 = $order_data['shipping']['address_1'];
    $order_shipping_address_2 = $order_data['shipping']['address_2'];
    $order_shipping_city = $order_data['shipping']['city'];
    $order_shipping_state = $order_data['shipping']['state'];
    $order_shipping_postcode = $order_data['shipping']['postcode'];
    $order_shipping_country = $order_data['shipping']['country'];
    

    使用 WC_Order_Item_Product 和 WC_Order_Item 方法获取订单项并访问数据:
    $order = wc_get_order($order_id);
    
    // Iterating through each WC_Order_Item_Product objects
    foreach ($order->get_items() as $item_key => $item_values):
    
        ## Using WC_Order_Item methods ##
    
        // Item ID is directly accessible from the $item_key in the foreach loop or
        $item_id = $item_values->get_id();
    
        ## Using WC_Order_Item_Product methods ##
    
        $item_name = $item_values->get_name(); // Name of the product
        $item_type = $item_values->get_type(); // Type of the order item ("line_item")
    
        $product_id = $item_values->get_product_id(); // the Product id
        $wc_product = $item_values->get_product(); // the WC_Product object
        ## Access Order Items data properties (in an array of values) ##
        $item_data = $item_values->get_data();
    
        $product_name = $item_data['name'];
        $product_id = $item_data['product_id'];
        $variation_id = $item_data['variation_id'];
        $quantity = $item_data['quantity'];
        $tax_class = $item_data['tax_class'];
        $line_subtotal = $item_data['subtotal'];
        $line_subtotal_tax = $item_data['subtotal_tax'];
        $line_total = $item_data['total'];
        $line_total_tax = $item_data['total_tax'];
    
    endforeach;
    

    关于php - 如何在 wordpress/woocommerce 中获取所有订单详细信息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31672200/

    相关文章:

    PHP 函数只能工作一次

    php - While 循环在满足条件时不中断

    php - 插件 API 出了点问题

    php - 操作 =""在 WordPress 中不起作用

    php - 自定义 Wordpress Woocommerce 帐单地址编辑表单

    wordpress - 替换 WooCommerce 中的可变产品定价

    php - Sqlite PHP 权限问题/写入不同的文件夹

    php - 为什么在 Laravel 中搜索(wherehas)关系中的小数列需要这么长时间?

    javascript - 数据未通过 wp_localize_script 正确传递

    jquery - Woocommerce 结账 + 购物车白色不透明度类 ="processing"