以编程方式更新Woocommerce订单上修改的日期



我得到了一份待处理订单的列表,获取了一些数据,并确定帖子是否在两周内最后一次编辑。如果不是,我正在做一些事情,然后试图将修改后的日期设置为今天,update_post_meta不起作用,它什么也没做。我所有宣布的vars都在顶级工作,我正在进入if语句。

$customer_orders = wc_get_orders(array(
'limit'    => -1,
'status'   => array('wc-pending')
) );
foreach($customer_orders as $order) {
$orderData = $order->get_data();
$orderId = $orderData['id'];
$orderDate = $orderData['date_modified']->date('Y-m-d H:i:s');
$orderDatePlus2Weeks = new DateTime($orderDate);
$orderDatePlus2Weeks->add(new DateInterval('P14D'));
$orderDatePlus2Weeks = $orderDatePlus2Weeks->format('Y-m-d H:i:s');
$today = date("Y-m-d H:i:s");
if($orderDatePlus2Weeks <= $today){
echo 'THIS ORDER NEEDS UPDATED';
// Do Some Stuff
update_post_meta($orderId, 'date_modified', $today);
}else{
echo 'THIS ORDER DOES NOT NEED UPDATED';
}
}

由于Wooccommerce 3和CRUD对象,您可以使用WC_Ordergetters和setters方法。试试这个:

$customer_orders = wc_get_orders(array(
'limit'    => -1,
'status'   => array('wc-pending')
) );
foreach($customer_orders as $order) {
$order_id = $order->get_id();
$date_modified = $order->get_date_modified();
$time_zone = $date_modified->getTimezone();
$date_modified_p14d = new DateTime($date_modified);
$date_modified_p14d->add(new DateInterval('P14D'));
$now = new DateTime();
$now->setTimezone($time_zone);
if( $date_modified_p14d->getTimestamp() <= $now->getTimestamp() ){
echo 'THIS ORDER NEEDS UPDATED';
// Do Some Stuff
$order->set_date_modified($now->getTimestamp());
$order->save();
}else{
echo 'THIS ORDER DOES NOT NEED UPDATED';
}
}

测试并工作。

最新更新