簡體   English   中英

Woocommerce:更新所有產品的功能

[英]Woocommerce: function to update all products

我的 Woocommerce 產品有問題。 如果我只是更新產品(編輯產品並單擊“更新”按鈕)而不進行任何更改,則此問題已解決。

我的站點中有大約 2000 種產品,然后我想使用我的 function.php 文件中的函數來執行此操作。

應該是這樣的,我只需要更新產品的行。

function update_all_products(){

    // getting all products
    $products = get_posts( $args );

    // Going through all products
    foreach ( $products as $key => $value ) {

        // the product ID
        $product_id = $value->ID;

        // update product
        update_post_meta...(NEED HELP HERE)...

   } //..end foreach
}

// fire the function
update_all_products();

嘗試以下操作,每次都會將您的產品更新 200 以避免出現問題(如果您也有可變產品,則post_type arg 將需要是product & product_variation

 add_action( 'woocommerce_loaded', 'update_products_by_x' );
function update_products_by_x(){
    $limit = 200;

    // getting all products
    $products_ids = get_posts( array(
        'post_type'        => 'product', // or ['product','product_variation'],
        'numberposts'      => $limit,
        'post_status'      => 'publish',
        'fields'           => 'ids',
        'meta_query'       => array( array(
            'key'     => '_sync_updated',
            'compare' => 'NOT EXISTS',
        ) )
    ) );

    // Loop through product Ids
    foreach ( $products_ids as $product_id ) {

        // Get the WC_Product object
        $product = wc_get_product($product_id);

        // Mark product as updated
        $product->update_meta_data( '_sync_updated', true );

        $product->save();
    }
}

代碼位於活動子主題(或活動主題)的 function.php 文件中。 測試和工作。

每次您瀏覽站點的頁面時,都會觸發該功能。 按 200 處理產品更安全,並且將避免超時或錯誤。

例如,您可以將該數字增加到 500,將$limit設置為500

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM