我在尝试通过对象$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.');
}
?>
答案 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
,因此它不会执行其他代码。