如何在Magento中为SKU价格添加新价值?

时间:2017-03-31 09:23:59

标签: magento

我是 Magento 的新手,我创建了我的代码以删除特价商品 并为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();
}

1 个答案:

答案 0 :(得分:0)

我不太确定你是如何形成包含你的产品的阵列的&#39; 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();

}

(为了防止大型集合中的内存耗尽,您应该使用 Mage_Core_Model_Resource_Iterator 而不是foreach循环。例如,您可以阅读here。)