开发者社区> 问答> 正文

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

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

展开
收起
游客ufivfoddcd53c 2020-01-04 11:12:14 1066 0
1 条回答
写回答
取消 提交回答
  • 我不太确定您是如何形成包含产品的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();
    
    }
    
    2020-01-04 11:12:49
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
阿里云搜索产品年度升级发布 立即下载
商业流量的精准在线分配 立即下载
库存平衡中心联合解决方案 立即下载