2016-05-16 59 views
0

我正在使用Magento 1.X API magento。我想在magento中创建产品,所以我使用catalogProductCreate方法创建。在Magento中创建多个产品

当它在5 to 10 products左右时,它工作的很好,但是当试图插入多个产品时需要花费很多时间。

是否有任何方法一次插入散装产品?

回答

0

在处理大型数据集时,在Magento中添加产品的API /编程/数据流方法非常缓慢。

如果您还没有看过它,请尝试Magmi - 这是Magento产品目录管理的缺失部分。您可以使用电子表格在几分钟内添加/更新数千种产品。它也可以在CLI中调用,从而开启许多优秀的自动化可能性。

哦,最重要的 - 它是免费的。

https://github.com/dweeves/magmi-git

0

我一直在使用这个代码来添加/更新产品上的Magento。

<?php 
include_once("app/Mage.php"); 
Mage::app(); 
umask(0); 
Mage::app()->setCurrentStore(Mage::getModel('core/store')->load(Mage_Core_Model_App::ADMIN_STORE_ID)); 

$counter = 0; 

我有这个函数来获取(或创建)一个产品的SKU:

function GetProduct($sku) 
{ 
    global $counter; 
    echo $sku; 
    $p = Mage::getModel('catalog/product'); 
    $productId = $p -> getIdBySku($sku);  
    if($productId) 
    { 
     echo "!"; 
     $p -> load($productId); 
    } 
    else 
    { 
     $p->setTypeId('simple'); 
     $p->setVisibility(Mage_Catalog_Model_Product_Visibility::VISIBILITY_BOTH); 
     $p->setStatus(1); 
     $p->setTaxClassId(7); 
     $p->setWebsiteIDs(array(1)); 
     $p->setStoreIDs(array(1)); 
     $p->setAttributeSetId(4); 
     $p->setSku($sku); 
    } 
    echo "..."; 
    $counter++; 
    echo " ".$counter; 
    return $p; 
} 

这里的功能,节省产品:

function SaveProduct($p) 
{ 
    try 
    { 
     if (is_array($errors = $p->validate())) 
     { 
      $strErrors = array(); 
      foreach($errors as $code=>$error) 
      { 
       $strErrors[] = ($error === true)? Mage::helper('catalog')->__('Attribute "%s" is invalid.', $code) : $error; 
       echo $strErrors[0]; 
      } 
      $this->_fault('data_invalid', implode("\n", $strErrors)); 
     } 
     $p->save(); 
     echo "\n"; 
    } 
    catch (Mage_Core_Exception $e) 
    { 
     $this->_fault('data_invalid', $e->getMessage()); 
    } 
} 

最后我打电话像这样:

$product = GetProduct('sku1'); 
$product->setData('thumbnail_label', 'sku1'); 
SaveProduct($product); 
unset($product); 
$product = GetProduct('sku2'); 
$product->setData('url_path', 'plastic-hat.html'); 
SaveProduct($product); 
unset($product); 
$product = GetProduct('sku3'); 
$product->setData('thumbnail_label', 'sku3'); 
SaveProduct($product); 
unset($product); 
$product = GetProduct('sku4'); 
$product->setData('thumbnail_label', 'sku4'); 
SaveProduct($product); 
unset($product); 
$product = GetProduct('sku5'); 
$product->setData('thumbnail_label', 'sku5'); 
SaveProduct($product); 
unset($product); 

我从命令行运行这段代码,因为有这样的内存泄漏。在内存爆炸之前,你只能获得更多的产品更新,而且你必须编辑并重新运行代码才能继续进行,但它可以工作,而且速度相对较快。