Prestashop 1.6.0.9 - $ product-> save()循环只需10个产品

时间:2015-01-15 10:59:35

标签: php xml import prestashop prestashop-1.6

我在尝试通过对象$product为我的商店推出一些xml导入时遇到问题。当我尝试填写$product成员时,一切正常,它遍布cca。我的xml中有800种产品。但是当我在循环结束时添加方法保存时,它只需要前10个产品而且永远不会做更多。

我试图将sleep(1)放在$product->save()之后,因为我认为SQL会因为大量收入查询而丢弃连接,但它也没有帮助。

你们知道为什么会这样吗?下面是我的代码(我没有在这里粘贴xml文件,因为我认为它并不重要)。

使用Prestashop 1.6.0.9。

<?            
include('../config/config.inc.php');
include('../init.php');    

if (file_exists('exportgoods.xml')) 
{
    $xml = simplexml_load_file('exportgoods.xml');


    foreach ($xml->PRODUCTS->PRODUCT as $jmena_produktu)
    {
        if($jmena_produktu->PRODUCER == "2"):           
        $reference=$string = str_replace(' ', '', $jmena_produktu->NAME);    
        $id_product = (int)Db::getInstance()->getValue('SELECT id_product FROM '._DB_PREFIX_.'product WHERE reference = \''.pSQL($reference).'\'');
        $product = $id_product ? new Product((int)$id_product, true) : new Product();
        $product->reference = $reference;
        $product->price = (float)$jmena_produktu->PRICEWITHDPH;
        $product->id_category_default = 2;
        $product->category = 15;
        $product->name[1] = (string)$jmena_produktu->NAME;
        $product->description[1] = (string)$jmena_produktu->LONGDESCRIPTION;
        $product->description_short[1] = (string)$jmena_produktu->DESCRIPTION;
        $product->link_rewrite[1] = Tools::link_rewrite($reference);
        if (!isset($product->date_add) || empty($product->date_add))
            $product->date_add = date('Y-m-d H:i:s');
        $product->date_upd = date('Y-m-d H:i:s');
        $id_product ? $product->updateCategories(array(2,15)) : $product->addToCategories(array(2,15));
        #Here start my problem
        $product->save();
        echo 'Product <b>'.$product->name[1].'</b> '.($id_product ? 'updated' : 'created').'<br />';
        endif;
    }
} 
else 
{
    exit('Failed to open exportgoods.xml.');
}
?>

1 个答案:

答案 0 :(得分:0)

我记得有过类似的问题而我也在使用simplexml_load_file()。我当时不确定那是不是问题,但这里什么都没有:

$data = file_get_contents('exportgoods.xml');
$xml = new SimpleXMLElement($data);

有时,XML元素彼此嵌套,与您在var_dump($xml)print_r($xml)上看到的内容不同。 如果你问我,XML就是一个奇怪的野兽。

当你打印$jmena_produktu->NAME时,你会看到什么,只是为了检查它是否比10更进一步。这样的事情:

foreach ($xml->PRODUCTS->PRODUCT as $jmena_produktu)
{
    echo $jmena_produktu->NAME . '</br>';    
}
exit;

请注意exit,因此它不会执行其他代码。