我正在使用Magento 1.X API
处理magento。我想用magento创建产品,所以我使用catalogProductCreate
方法创建。
当它在5 to 10 products
附近时效果很好,但在尝试插入多个产品时需要花费很多时间。
是否有任何方法可以一次插入批量产品。
答案 0 :(得分:0)
在处理大型数据集时,在Magento中添加产品的API /编程/数据流方法非常慢。
如果您还没有看过它,请尝试Magmi - 它是Magento目录管理中缺失的部分。您可以使用电子表格在几分钟内添加/更新数千种产品。它也可以在CLI上调用,这开启了许多出色的自动化可能性。
哦,最重要的是 - 它是免费的。
答案 1 :(得分: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);
我从命令行运行此代码,因为以这种方式运行内存泄漏。你只能在打破内存之前更新这么多产品,你必须编辑并重新运行代码才能继续运行,但它的工作原理相对较快。