我创建了代码以删除特价商品并为SKU添加新价格。
我可以取消特价,但不能为SKU添加新价格。如何才能做到这一点?
我的代码如下:
$productIds[][] = array('DF-12''200','DF-98''300','DF-87''400');
$products = Mage::getResourceModel('catalog/product_collection')
->addAttributeToSelect('*') // <- careful with this
->addAttributeToFilter(
'sku', array('in' => $productIds[0])
)
->load();
foreach ($products as $_product){
$product = Mage::getModel('catalog/product')->load($_product->getId());
$product->setprice($productIds[1])
$product->setOffertext('');
$product->setSpecialFromDate('');
$product->setSpecialToDate('');
$product->setSpecialPrice('');
$product->save();
}
我不太确定您是如何形成包含产品的SKU和价格的阵列的,对我来说似乎不对。但是,由于我只能用给定的信息推测那部分,因此,以示例方式以编程方式更新较小的产品系列可能会更有帮助。该代码段在后端模型中对我有用:
// array('sku' => price )
$productPricesBySku = array('DF-1234' => 180.00, 'DF-1235' => 99.95);
$collection = Mage::getModel('catalog/product')->getCollection()
->addAttributeToSelect('price') // optional
->addAttributeToSelect('special_from_date') // optional
->addAttributeToSelect('special_to_date') // optional
->addAttributeToFilter('sku', array('in'=>array_keys($productPricesBySku)));
foreach($collection as $_product){
if(!($price=$productPricesBySku[$_product->getSku()])) continue;
// no need to load the product again
// just set the data directly on our collection-item and save it
$_product->setPrice((float)$price)
->setSpecialFromDate('')
->setSpecialToDate('')
->setSpecialPrice('')
->save();
}
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。