Comment ajouter un produit dans woocommerce avec du code php [fermé]

22

Je souhaite ajouter des produits avec du code PHP comme ci-dessous:

$post_information = array(
  'post_title' => 'new item shop',
  'post_content' => 'this is new item shop',
  'post_type' => 'post',
  'post_status' => 'publish'
);
$post_id = wp_insert_post($post_information);

mais ce code optimise pour WooCommerce, tel que le type de message, les indications, les métadonnées et ... Quelqu'un peut-il vous aider?

    
posée Hossein Hashemi 10.03.2014 - 20:43

1 réponse

43

C'est assez facile, vous avez élaboré les données ajoutées dans le post méta. Le problème, c’est d’ajouter des produits téléchargeables au magasin.

ci-dessous est le code que j'utilise. Il répertorie toutes les méta-publications utilisées par woo commerce. Ceci publie un produit mais le lien de téléchargement ne sera pas attaché.

À l'origine, quand j'ai commencé, j'ai commis une erreur avec le tableau qui stockait le lien de téléchargement, produisant un mauvais lien "b" suivi d'un deuxième fichier de téléchargement correct. Après avoir corrigé le tableau pour qu’il corresponde à celui d’un produit ajouté manuellement, aucun fichier ne sera affiché. Si quelqu'un a des infos à ce sujet, il serait grandement apprécié

$post = array(
    'post_author' => $user_id,
    'post_content' => '',
    'post_status' => "publish",
    'post_title' => $product->part_num,
    'post_parent' => '',
    'post_type' => "product",
);

//Create post
$post_id = wp_insert_post( $post, $wp_error );
if($post_id){
    $attach_id = get_post_meta($product->parent_id, "_thumbnail_id", true);
    add_post_meta($post_id, '_thumbnail_id', $attach_id);
}

wp_set_object_terms( $post_id, 'Races', 'product_cat' );
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', 'yes');
update_post_meta( $post_id, '_virtual', 'yes');
update_post_meta( $post_id, '_regular_price', "1" );
update_post_meta( $post_id, '_sale_price', "1" );
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', "");
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', "1" );
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', "" );

// file paths will be stored in an array keyed off md5(file path)
$downdloadArray =array('name'=>"Test", 'file' => $uploadDIR['baseurl']."/video/".$video);

$file_path =md5($uploadDIR['baseurl']."/video/".$video);


$_file_paths[  $file_path  ] = $downdloadArray;
// grant permission to any newly added files on any existing orders for this product
// do_action( 'woocommerce_process_product_file_download_paths', $post_id, 0, $downdloadArray );
update_post_meta( $post_id, '_downloadable_files', $_file_paths);
update_post_meta( $post_id, '_download_limit', '');
update_post_meta( $post_id, '_download_expiry', '');
update_post_meta( $post_id, '_download_type', '');
update_post_meta( $post_id, '_product_image_gallery', '');

espérons que cela est conforme à la norme de qualité:)

    
réponse donnée user3361421 11.03.2014 - 11:42

Lire d'autres questions sur les étiquettes