我必须添加此功能,我想知道在编写插件之前是否存在这样的插件。
答案 0 :(得分:5)
我创建了一个插件,禁用文件不在CSV中。我更喜欢禁用这些项目,而不是在出现问题时实际删除它们(它不会擦除我的数据库)。
创建插件文件magmi/plugins/extra/general/itemdisabler/magmi_itemdisabler_plugin.php
在文件中,粘贴以下内容并保存:
插件代码:
<?php
class Magmi_ItemdisablerPlugin extends Magmi_ItemProcessor
{
protected $datasource_skus = array();
public function getPluginInfo()
{
return array("name"=>"Magmi Magento Item Disabler",
"author"=>"Axel Norvell (axelnorvell.com)",
"version"=>"1.0.6");
}
public function afterImport()
{
$this->log("Running Item Disabler Plugin","info");
$this->disableItems();
return true;
}
public function getPluginParams($params)
{
return array();
}
public function isRunnable()
{
return array(true,"");
}
public function initialize($params)
{
}
public function processItemAfterId(&$item,$params=null)
{
if(isset($item['sku']))
{
$this->datasource_skus[] = $item['sku'];
}
}
public function disableItems()
{
if(count($this->datasource_skus) <= 0)
{
$this->log('No items were found in datasource. Item Disabler will not run.', "info");
return false; /* Nothing to disable */
}
//Setup tables
$ea = $prefix!=""?$prefix."eav_attribute":"eav_attribute";
$eet = $prefix!=""?$prefix."eav_entity_type":"eav_entity_type";
$cpe = $prefix!=""?$prefix."catalog_product_entity":"catalog_product_entity";
$cpei = $prefix!=""?$prefix."catalog_product_entity_int":"catalog_product_entity_int";
//Get "status" attribute_id
$status_attr_id = "
SELECT ea.attribute_id FROM $ea ea
LEFT JOIN $eet eet ON ea.entity_type_id = eet.entity_type_id
WHERE ea.attribute_code = 'status'
AND eet.entity_type_code = 'catalog_product'";
$result = $this->selectAll($status_attr_id);
if (count($result) == 1) {
$attribute_id = $result[0]['attribute_id'];
}
unset($result);
//Get all active items
$sql = "SELECT e.sku, e.entity_id FROM $cpei i
INNER JOIN $cpe e ON
e.entity_id = i.entity_id
WHERE attribute_id=?
AND i.value = 1";
$all_magento_items = $this->selectAll($sql, array($attribute_id));
//Setup the magento_skus array for easy processing.
$magento_skus = array();
foreach($all_magento_items as $item)
{
$this->log("{$item['sku']} found in Mage", "info");
$magento_skus[$item['sku']] = $item['entity_id'];
}
//process the array, move anything thats in the datasource.
foreach($this->datasource_skus as $sku)
{
if(isset($magento_skus[$sku]))
{
unset($magento_skus[$sku]);
}
}
if(!empty($magento_skus))
{
foreach($magento_skus as $sku => $id)
{
$this->log("Disabling Item Id $id with SKU: $sku", "info");
$this->update("
UPDATE $cpei i
INNER JOIN $cpe e ON
e.entity_id = i.entity_id
SET VALUE = '2'
WHERE attribute_id = ?
AND i.value = 1
AND e.sku=?", array($attribute_id, $sku));
}
}
else
{
//If the Datasource contains all Magento's items.
$this->log('All items present in datasource. No items to disable.', "info");
}
}
}
然后登录Magmi,启用插件并运行导入。导入完成后将执行此插件。它打开数据源,记录所有SKU,然后将它们与Magento数据库进行比较。将禁用在数据源中找不到的任何skus。这个插件可以更好地优化,但它现在可以正常工作。
答案 1 :(得分:2)
我认为肯定删除而不是省略删除会更好。修改转换适配器以解析列(例如“已删除”)并将_isDeleted
属性设置为true
应该是微不足道的。这将导致产品在保存时被删除。
参考Mage_Core_Model_Abstract
和Varien_Object
。
答案 2 :(得分:0)
我已经尝试使用内置的产品删除程序,但它没有按预期工作。它会删除旧产品,但是当它再次添加时会增加产品编号,因此在进行一些导入后,您的产品编号为1xxxxx。
如果我只有从CSV导入的产品而且没有“始终”的产品,我实际上在magmi之前使用php脚本删除所有产品:
<?php
$mysqli = new mysqli("localhost", "dbuser", "dbpassword", "db");
/* check connection */
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
$query = "
SET FOREIGN_KEY_CHECKS = 0;
TRUNCATE TABLE `catalog_product_bundle_price_index`;
TRUNCATE TABLE `catalog_product_bundle_selection`;
TRUNCATE TABLE `catalog_product_bundle_selection_price`;
TRUNCATE TABLE `catalog_product_bundle_option_value`;
TRUNCATE TABLE `catalog_product_bundle_option`;
TRUNCATE TABLE `catalog_product_entity_datetime`;
TRUNCATE TABLE `catalog_product_entity_decimal`;
TRUNCATE TABLE `catalog_product_entity_gallery`;
TRUNCATE TABLE `catalog_product_entity_group_price`;
TRUNCATE TABLE `catalog_product_entity_int`;
TRUNCATE TABLE `catalog_product_entity_media_gallery`;
TRUNCATE TABLE `catalog_product_entity_media_gallery_value`;
TRUNCATE TABLE `catalog_product_entity_text`;
TRUNCATE TABLE `catalog_product_entity_tier_price`;
TRUNCATE TABLE `catalog_product_entity_varchar`;
TRUNCATE TABLE `catalog_product_flat_1`;
TRUNCATE TABLE `catalog_product_link`;
TRUNCATE TABLE `catalog_product_link_attribute_decimal`;
TRUNCATE TABLE `catalog_product_link_attribute_int`;
TRUNCATE TABLE `catalog_product_link_attribute_varchar`;
TRUNCATE TABLE `catalog_product_option`;
TRUNCATE TABLE `catalog_product_option_price`;
TRUNCATE TABLE `catalog_product_option_title`;
TRUNCATE TABLE `catalog_product_option_type_price`;
TRUNCATE TABLE `catalog_product_option_type_title`;
TRUNCATE TABLE `catalog_product_option_type_value`;
TRUNCATE TABLE `catalog_product_super_attribute_label`;
TRUNCATE TABLE `catalog_product_super_attribute_pricing`;
TRUNCATE TABLE `catalog_product_super_attribute`;
TRUNCATE TABLE `catalog_product_super_link`;
TRUNCATE TABLE `catalog_product_enabled_index`;
TRUNCATE TABLE `catalog_product_website`;
TRUNCATE TABLE `catalog_category_product_index`;
TRUNCATE TABLE `catalog_product_index_price`;
TRUNCATE TABLE `catalog_product_index_eav`;
TRUNCATE TABLE `catalog_category_product`;
TRUNCATE TABLE `catalog_product_index_eav_idx`;
TRUNCATE TABLE `catalog_product_entity`;
TRUNCATE TABLE `catalog_product_relation`;
TRUNCATE TABLE `catalog_product_index_price_idx`;
TRUNCATE TABLE `catalog_product_index_website`;
TRUNCATE TABLE `cataloginventory_stock_item`;
TRUNCATE TABLE `cataloginventory_stock_status`;
TRUNCATE TABLE `core_url_rewrite`;
SET FOREIGN_KEY_CHECKS = 1;
";
$results = mysqli_multi_query($mysqli,$query);
$mysqli->close();
?>
希望有所帮助。
答案 3 :(得分:0)
我想我会提到,如果人们有一个非常大的产品列表并且他们试图运行这个禁用程序,那么人们可能会遇到问题。我对magmi并不是很熟悉,但是在使用cli时似乎会出现更多错误,所以如果你注意到这种错误不起作用,请尝试测试。它不适合我,我把它缩小到php内存限制。我不得不改变脚本以包含ini_set('memory_limit','512M');在disableItems函数中。
所以,我现在看起来像这样......
public function disableItems()
{
ini_set('max_execution_time', 0);
set_time_limit(0);
ini_set('memory_limit','512M');
umask(0);
我希望如果他们遇到任何问题,可以帮助任何人。我也不得不设置我的运行只要它需要和一切。最好在配置文件中设置它,但这是一个快速解决方案,尤其是当您在共享主机上时。
答案 4 :(得分:0)
这是一个Magmi插件,它正是你正在寻找的东西:http://www.emvee-solutions.com/blog/magmi-delete-disable-products-missing-csv-source/