我是Magento的新手,我正在做一项cron工作,在指定日期后删除特定类别中的产品。在Stackoverflow的帮助下,我想出了这个代码:
require_once 'app/Mage.php';
Mage::app();
$date = Mage::getModel('core/date')->date('Y-m-d H:i:s');
$collection = Mage::getModel('catalog/product')->getCollection();
$collection->addfieldtofilter('news_to_date', array(array('to' => $date)));
foreach($collection as $product) {
$product->setStatus(Mage_Catalog_Model_Product_Status::STATUS_DISABLED);
$product->save();
}
这会检查实际日期并将其与产品的日期进行比较。如果日期已过,则产品将被禁用。我需要的是,代码应该删除该类别的产品(在这种情况下,类别是"销售"),而不是禁用产品
我希望你们能帮助我!
提前感谢!
您需要从product中获取所有类别ID,然后从类别ID数组中删除Sales类别ID,并将其设置回product。
例如,销售类别ID为5。
foreach ($collection as $product) {
//Getting all category ids
$ids = $product->getCategoryIds();
//Searching array key with value 5 and removing from array
if (($key = array_search(5, $ids)) !== false) {
unset($ids[$key]);
$product->setCategoryIds($ids)
$product->save();
}
}
附言:你可以使用magento cron作业功能,比你不需要使用:
require_once 'app/Mage.php';
Mage::app();