在Magento中创建多个产品

时间:2016-05-16 11:16:52

标签: magento magento-1.7

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

当它在5 to 10 products附近时效果很好,但在尝试插入多个产品时需要花费很多时间。

是否有任何方法可以一次插入批量产品。

2 个答案:

答案 0 :(得分:0)

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

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

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

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

答案 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);

我从命令行运行此代码,因为以这种方式运行内存泄漏。你只能在打破内存之前更新这么多产品,你必须编辑并重新运行代码才能继续运行,但它的工作原理相对较快。