Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/wordpress/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 使用Woocommerce 3中的CRUD方法以编程方式创建产品_Php_Wordpress_Woocommerce_Product_Crud - Fatal编程技术网

Php 使用Woocommerce 3中的CRUD方法以编程方式创建产品

Php 使用Woocommerce 3中的CRUD方法以编程方式创建产品,php,wordpress,woocommerce,product,crud,Php,Wordpress,Woocommerce,Product,Crud,我想用PHP代码以编程方式创建一个新的Woocommerce产品,我已经用Woocommerce 3 CRUD方法进行了尝试: //Woocommerce CRUD $objProduct = new WC_Product_Simple(); $objProduct->set_name('My Product 1'); //Set product name. $objProduct->set_status('publish'); //Set product status. //$o

我想用PHP代码以编程方式创建一个新的Woocommerce产品,我已经用Woocommerce 3 CRUD方法进行了尝试:

//Woocommerce CRUD
$objProduct = new WC_Product_Simple();

$objProduct->set_name('My Product 1'); //Set product name.
$objProduct->set_status('publish'); //Set product status.
//$objProduct->set_featured(FALSE); //Set if the product is featured.                          | bool
$objProduct->set_catalog_visibility('visible'); //Set catalog visibility.                   | string $visibility Options: 'hidden', 'visible', 'search' and 'catalog'.
$objProduct->set_description('My custom long description'); //Set product description.
//$objProduct->set_short_description('My short description'); //Set product short description.
//$objProduct->set_sku('U-123'); //Set SKU

$objProduct->set_price(5.00); //Set the product's active price.
//$objProduct->set_regular_price(5.00); //Set the product's regular price.
//$objProduct->set_sale_price(); //Set the product's sale price.
//$objProduct->set_date_on_sale_from(); //Set date on sale from.                              | string|integer|null $date UTC timestamp, or ISO 8601 DateTime. If the DateTime string has no timezone or offset, WordPress site timezone will be assumed. Null if their is no date.
//$objProduct->set_date_on_sale_to();//Set date on sale to.                                   | string|integer|null $date UTC timestamp, or ISO 8601 DateTime. If the DateTime string has no timezone or offset, WordPress site timezone will be assumed. Null if their is no date.

//$objProduct->set_manage_stock(TRUE); //Set if product manage stock.                         | bool
//$objProduct->set_stock_quantity(10); //Set number of items available for sale.
//$objProduct->set_stock_status('instock'); //Set stock status.                               | string $status 'instock', 'outofstock' and 'onbackorder'
//$objProduct->set_backorders('no'); //Set backorders.                                        | string $backorders Options: 'yes', 'no' or 'notify'.
//$objProduct->set_sold_individually(FALSE); //Set if should be sold individually.            | bool

//$objProduct->set_weight(); //Set the product's weight.
//$objProduct->set_length(); //Set the product length.
//$objProduct->set_width(); //Set the product width.
//$objProduct->set_height(); //Set the product height.

//$objProduct->set_upsell_ids($upsell_ids); //Set upsell IDs.                               | array $upsell_ids IDs from the up-sell products.
//$objProduct->set_cross_sell_ids($cross_sell_ids); //Set crosssell IDs.                    | array $cross_sell_ids IDs from the cross-sell products.

$objProduct->set_reviews_allowed(TRUE); //Set if reviews is allowed.                        | bool

//$objProduct->set_purchase_note($purchase_note); //Set purchase note.                      | string $purchase_note Purchase note.


$attribute = new WC_Product_Attribute();
$attribute->set_id(wc_attribute_taxonomy_id_by_name('pa_color')); //if passing the attribute name to get the ID
$attribute->set_name('pa_color'); //attribute name
$attribute->set_options('red'); // attribute value
$attribute->set_position(1); //attribute display order
$attribute->set_visible(1); //attribute visiblity
$attribute->set_variation(0);//to use this attribute as varint or not

$raw_attributes[] = $attribute; //<--- storing the attribute in an array

$attribute = new WC_Product_Attribute();
$attribute->set_id(25);
$attribute->set_name('pa_size');
$attribute->set_options('XL');
$attribute->set_position(2);
$attribute->set_visible(1);
$attribute->set_variation(0);

$raw_attributes[] = $attribute; //<--- storing the attribute in an array

$objProduct->set_attributes($raw_attributes); //Set product attributes.                   | array $raw_attributes Array of WC_Product_Attribute objects.

//$objProduct->set_category_ids($term_ids); //Set the product categories.                   | array $term_ids List of terms IDs.
//$objProduct->set_tag_ids($term_ids); //Set the product tags.                              | array $term_ids List of terms IDs.

//$objProduct->set_image_id(); //Set main image ID.                                         | int|string $image_id Product image id.
//$objProduct->set_gallery_image_ids(); //Set gallery attachment ids.                       | array $image_ids List of image ids.

$new_product_id = $objProduct->save(); //Saving the data to create new product, it will return product ID.

return;
}
//积垢
$objProduct=新的WC_产品_Simple();
$objProduct->set_name(“我的产品1”)//设置产品名称。
$objProduct->set_status('publish')//设置产品状态。
//$objProduct->set_特征(FALSE)//设置产品是否具有特色布尔
$objProduct->set_catalog_visibility('visible')//设置目录可见性字符串$visibility选项:“隐藏”、“可见”、“搜索”和“目录”。
$objProduct->set_description('My custom long description')//设置产品描述。
//$objProduct->set_short_description('My short description')//设置产品简短描述。
//$objProduct->set_sku('U-123')//设置SKU
$objProduct->set_price(5.00)//设置产品的有效价格。
//$objProduct->set_常规_价格(5.00)//设定产品的正常价格。
//$objProduct->set_sale_price()//设定产品的销售价格。
//$objProduct->set_date_on_sale_from()//设定销售日期为.|字符串|整数| null$日期UTC时间戳,或ISO 8601日期时间。如果DateTime字符串没有时区或偏移量,则假定WordPress站点时区。如果没有日期,则为空。
//$objProduct->set_date_on_sale_to()//将出售日期定为。|字符串|整数| null$日期UTC时间戳,或ISO 8601日期时间。如果DateTime字符串没有时区或偏移量,则假定WordPress站点时区。如果没有日期,则为空。
//$objProduct->set\u manage\u stock(TRUE)//设置产品是否管理库存布尔
//$OBJ产品->设置库存数量(10)//设置可供销售的商品数量。
//$objProduct->设置库存状态(“库存”)//设置库存状态字符串$status'instock'、'outofstock'和'onbackorder'
//$objProduct->set_backorders('no')//安排延期交货字符串$backorders选项:“是”、“否”或“通知”。
//$objProduct->set\u selled\u单独销售(FALSE)//设置是否应单独出售布尔
//$objProduct->set_weight()//设置产品的重量。
//$objProduct->set_length()//设置产品长度。
//$objProduct->set_width()//设置产品宽度。
//$objProduct->set_height()//设置产品高度。
//$objProduct->set_upsell_id($upsell_id)//设置向上销售标识数组$upsell\u标识来自upsell产品的ID。
//$objProduct->set_cross_sell_id($cross_sell_id)//设置交叉销售标识数组$cross_sell_ID来自cross sell产品。
$objProduct->set\u reviews\u allowed(TRUE)//设置是否允许审核布尔
//$objProduct->set_purchase_note($purchase_note)//设置购买说明字符串$purchase\u note purchase note。
$attribute=新的WC_产品_属性();
$attribute->set_id(wc_attribute_taxonomy_id_by_name('pa_color'))//如果传递属性名以获取ID
$attribute->set_name('pa_color')//属性名
$attribute->set_选项('red');//属性值
$attribute->set_位置(1)//属性显示顺序
$attribute->set_可见(1)//属性可见性
$attribute->set_变量(0)//是否将此属性用作变量
$raw_attributes[]=$attribute//设置_id(25);
$attribute->set_name('pa_size');
$attribute->set_选项('XL');
$attribute->set_位置(2);
$attribute->set_可见(1);
$attribute->set_变量(0);
$raw_attributes[]=$attribute//设置属性($raw\u属性)//设置产品属性数组$raw_属性WC_产品_属性对象的数组。
//$objProduct->set_category_id($term_id)//设置产品类别数组$term\u ID术语ID列表。
//$objProduct->set_tag_id($term_id)//设置产品标签数组$term\u ID术语ID列表。
//$objProduct->set_image_id()//设置主图像标识。| int |字符串$image|u ID产品图像标识。
//$objProduct->set_gallery_image_ids()//设置画廊附件ID数组$image\u id图像标识的列表。
$new_product_id=$objProduct->save()//保存数据以创建新产品,它将返回产品ID。
返回;
}
但我得到了这个错误:

2018年10月22日20:25:19 UTC]PHP致命错误:未捕获错误:在/home/u1771p590/domains/famyfuerza.com/public\u html/store/wp content/plugins/ff dropship data scraper/ff dropship data scraper.PHP:165中找不到类“WC\u Product\u Simple” 堆栈跟踪:
-#0/home/u1771p590/domains/famyfuerza.com/public_html/store/wp content/plugins/ff dropship data scraper/ff dropship data scraper.php(233):curl_下载(“…”)
-#1/home/u1771p590/domains/famyfuerza.com/public_html/store/wp settings.php(305):包含一次('/home/u1771p590…')
-#2/home/u1771p590/domains/famyfuerza.com/public_html/store/wp config.php(112):需要_一次('/home/u1771p590…')
-#3/home/u1771p590/domains/famyfuerza.com/public_html/store/wp load.php(37):需要_一次('/home/u1771p590…')
-#4/home/u1771p590/domains/famyfuerza.com/public_html/store/wp admin/admin.php(31):需要一次('/home/u1771p590…')
-#5/home/u1771p590/domains/famyfuerza.com/public_html/store/wp admin/index.php(10):需要一次('/home/u1771p590…')
-#6{main}
在第165行输入/home/u1771p590/domains/famyfuerza.com/public_html/store/wp-content/plugins/ff-dropship-data-scraper/ff-dropship-data-scraper.php

我试图包含简单的产品类,但这产生了另一个错误,即缺少另一个类

有人知道怎么解决这个问题吗?或者有其他方法通过代码创建woocommerce产品?

另一种方法:,使用
wp\u insert\u post
功能

$item = array( 'Name' => 'Product A', 'Description' => 'This is a product A', 'SKU' => '10020030A', ); $user_id = get_current_user(); // this has NO SENSE AT ALL, because wp_insert_post uses current user as default value // $user_id = $some_user_id_we_need_to_use; // So, user is selected.. $post_id = wp_insert_post( array( 'post_author' => $user_id, 'post_title' => $item['Name'], 'post_content' => $item['Description'], 'post_status' => 'publish', 'post_type' => "product", ) ); wp_set_object_terms( $post_id, 'simple', 'product_type' ); update_post_meta( $post_id, '_visibility', 'visible' ); update_post_meta( $post_id, '_stock_status', 'instock'); update_post_meta( $post_id, 'total_sales', '0' ); update_post_meta( $post_id, '_downloadable', 'no' ); update_post_meta( $post_id, '_virtual', 'yes' ); update_post_meta( $post_id, '_regular_price', '' ); update_post_meta( $post_id, '_sale_price', '' ); update_post_meta( $post_id, '_purchase_note', '' ); update_post_meta( $post_id, '_featured', 'no' ); update_post_meta( $post_id, '_weight', '' ); update_post_meta( $post_id, '_length', '' ); update_post_meta( $post_id, '_width', '' ); update_post_meta( $post_id, '_height', '' ); update_post_meta( $post_id, '_sku', $item['SKU'] ); update_post_meta( $post_id, '_product_attributes', array() ); update_post_meta( $post_id, '_sale_price_dates_from', '' ); update_post_meta( $post_id, '_sale_price_dates_to', '' ); update_post_meta( $post_id, '_price', '' ); update_post_meta( $post_id, '_sold_individually', '' ); update_post_meta( $post_id, '_manage_stock', 'no' ); update_post_meta( $post_id, '_backorders', 'no' ); update_post_meta( $post_id, '_stock', '' );

// Custom function for product creation (For Woocommerce 3+ only)
function create_product( $args ){

    if( ! function_exists('wc_get_product_object_type') && ! function_exists('wc_prepare_product_attributes') )
        return false;

    // Get an empty instance of the product object (defining it's type)
    $product = wc_get_product_object_type( $args['type'] );
    if( ! $product )
        return false;

    // Product name (Title) and slug
    $product->set_name( $args['name'] ); // Name (title).
    if( isset( $args['slug'] ) )
        $product->set_name( $args['slug'] );

    // Description and short description:
    $product->set_description( $args['description'] );
    $product->set_short_description( $args['short_description'] );

    // Status ('publish', 'pending', 'draft' or 'trash')
    $product->set_status( isset($args['status']) ? $args['status'] : 'publish' );

    // Visibility ('hidden', 'visible', 'search' or 'catalog')
    $product->set_catalog_visibility( isset($args['visibility']) ? $args['visibility'] : 'visible' );

    // Featured (boolean)
    $product->set_featured(  isset($args['featured']) ? $args['featured'] : false );

    // Virtual (boolean)
    $product->set_virtual( isset($args['virtual']) ? $args['virtual'] : false );

    // Prices
    $product->set_regular_price( $args['regular_price'] );
    $product->set_sale_price( isset( $args['sale_price'] ) ? $args['sale_price'] : '' );
    $product->set_price( isset( $args['sale_price'] ) ? $args['sale_price'] :  $args['regular_price'] );
    if( isset( $args['sale_price'] ) ){
        $product->set_date_on_sale_from( isset( $args['sale_from'] ) ? $args['sale_from'] : '' );
        $product->set_date_on_sale_to( isset( $args['sale_to'] ) ? $args['sale_to'] : '' );
    }

    // Downloadable (boolean)
    $product->set_downloadable(  isset($args['downloadable']) ? $args['downloadable'] : false );
    if( isset($args['downloadable']) && $args['downloadable'] ) {
        $product->set_downloads(  isset($args['downloads']) ? $args['downloads'] : array() );
        $product->set_download_limit(  isset($args['download_limit']) ? $args['download_limit'] : '-1' );
        $product->set_download_expiry(  isset($args['download_expiry']) ? $args['download_expiry'] : '-1' );
    }

    // Taxes
    if ( get_option( 'woocommerce_calc_taxes' ) === 'yes' ) {
        $product->set_tax_status(  isset($args['tax_status']) ? $args['tax_status'] : 'taxable' );
        $product->set_tax_class(  isset($args['tax_class']) ? $args['tax_class'] : '' );
    }

    // SKU and Stock (Not a virtual product)
    if( isset($args['virtual']) && ! $args['virtual'] ) {
        $product->set_sku( isset( $args['sku'] ) ? $args['sku'] : '' );
        $product->set_manage_stock( isset( $args['manage_stock'] ) ? $args['manage_stock'] : false );
        $product->set_stock_status( isset( $args['stock_status'] ) ? $args['stock_status'] : 'instock' );
        if( isset( $args['manage_stock'] ) && $args['manage_stock'] ) {
            $product->set_stock_status( $args['stock_qty'] );
            $product->set_backorders( isset( $args['backorders'] ) ? $args['backorders'] : 'no' ); // 'yes', 'no' or 'notify'
        }
    }

    // Sold Individually
    $product->set_sold_individually( isset( $args['sold_individually'] ) ? $args['sold_individually'] : false );

    // Weight, dimensions and shipping class
    $product->set_weight( isset( $args['weight'] ) ? $args['weight'] : '' );
    $product->set_length( isset( $args['length'] ) ? $args['length'] : '' );
    $product->set_width( isset(  $args['width'] ) ?  $args['width']  : '' );
    $product->set_height( isset( $args['height'] ) ? $args['height'] : '' );
    if( isset( $args['shipping_class_id'] ) )
        $product->set_shipping_class_id( $args['shipping_class_id'] );

    // Upsell and Cross sell (IDs)
    $product->set_upsell_ids( isset( $args['upsells'] ) ? $args['upsells'] : '' );
    $product->set_cross_sell_ids( isset( $args['cross_sells'] ) ? $args['upsells'] : '' );

    // Attributes et default attributes
    if( isset( $args['attributes'] ) )
        $product->set_attributes( wc_prepare_product_attributes($args['attributes']) );
    if( isset( $args['default_attributes'] ) )
        $product->set_default_attributes( $args['default_attributes'] ); // Needs a special formatting

    // Reviews, purchase note and menu order
    $product->set_reviews_allowed( isset( $args['reviews'] ) ? $args['reviews'] : false );
    $product->set_purchase_note( isset( $args['note'] ) ? $args['note'] : '' );
    if( isset( $args['menu_order'] ) )
        $product->set_menu_order( $args['menu_order'] );

    // Product categories and Tags
    if( isset( $args['category_ids'] ) )
        $product->set_category_ids( $args['category_ids'] );
    if( isset( $args['tag_ids'] ) )
        $product->set_tag_ids( $args['tag_ids'] );


    // Images and Gallery
    $product->set_image_id( isset( $args['image_id'] ) ? $args['image_id'] : "" );
    $product->set_gallery_image_ids( isset( $args['gallery_ids'] ) ? $args['gallery_ids'] : array() );

    ## --- SAVE PRODUCT --- ##
    $product_id = $product->save();

    return $product_id;
}

// Utility function that returns the correct product object instance
function wc_get_product_object_type( $type ) {
    // Get an instance of the WC_Product object (depending on his type)
    if( isset($args['type']) && $args['type'] === 'variable' ){
        $product = new WC_Product_Variable();
    } elseif( isset($args['type']) && $args['type'] === 'grouped' ){
        $product = new WC_Product_Grouped();
    } elseif( isset($args['type']) && $args['type'] === 'external' ){
        $product = new WC_Product_External();
    } else {
        $product = new WC_Product_Simple(); // "simple" By default
    } 
    
    if( ! is_a( $product, 'WC_Product' ) )
        return false;
    else
        return $product;
}

// Utility function that prepare product attributes before saving
function wc_prepare_product_attributes( $attributes ){
    global $woocommerce;

    $data = array();
    $position = 0;

    foreach( $attributes as $taxonomy => $values ){
        if( ! taxonomy_exists( $taxonomy ) )
            continue;

        // Get an instance of the WC_Product_Attribute Object
        $attribute = new WC_Product_Attribute();

        $term_ids = array();

        // Loop through the term names
        foreach( $values['term_names'] as $term_name ){
            if( term_exists( $term_name, $taxonomy ) )
                // Get and set the term ID in the array from the term name
                $term_ids[] = get_term_by( 'name', $term_name, $taxonomy )->term_id;
            else
                continue;
        }

        $taxonomy_id = wc_attribute_taxonomy_id_by_name( $taxonomy ); // Get taxonomy ID

        $attribute->set_id( $taxonomy_id );
        $attribute->set_name( $taxonomy );
        $attribute->set_options( $term_ids );
        $attribute->set_position( $position );
        $attribute->set_visible( $values['is_visible'] );
        $attribute->set_variation( $values['for_variation'] );

        $data[$taxonomy] = $attribute; // Set in an array

        $position++; // Increase position
    }
    return $data;
}
$product_id = create_product( array(
    'type'               => '', // Simple product by default
    'name'               => __("The product title", "woocommerce"),
    'description'        => __("The product description…", "woocommerce"),
    'short_description'  => __("The product short description…", "woocommerce"),
    // 'sku'                => '',
    'regular_price'      => '5.00', // product price
    // 'sale_price'         => '',
    'reviews_allowed'    => true,
    'attributes'         => array(
        // Taxonomy and term name values
        'pa_color' => array(
            'term_names' => array('Red', 'Blue'),
            'is_visible' => true,
            'for_variation' => false,
        ),
        'pa_size' =>  array(
            'term_names' => array('X Large'),
            'is_visible' => true,
            'for_variation' => false,
        ),
    ),
) );  

// Displaying the created product ID
echo $product_id;