从admin产品网格将产品导出到csv

时间:2010-08-12 14:49:19

标签: magento grid dataflow

导入产品配置文件允许您按名称过滤要导出的产品,sku ... 我想在manage products页面中拥有相同的功能。 管理员将过滤网格中的产品,然后单击“导出”按钮以获取过滤后的产品。

如何添加“导出”按钮?我需要覆盖哪些模板/块? 当管理员单击按钮时,如何获取过滤后的集合? 如何将过滤后的集合导出到csv文件?我可以使用数据流吗?

由于

1 个答案:

答案 0 :(得分:9)

您需要在管理产品控制器中实施新的 massAction 。一个好的开始方法是查看产品控制器,看看其他massActions是如何实现的。

让我们来看看......首先,您需要将一个massAction声明添加到网格中。这可以在app / code / core / Mage / Adminhtml / Block / Catalog / Product / Grid.php中完成。您需要在_prepareMassaction方法中添加以下内容:

$this->getMassactionBlock()->addItem('export', array(
                'label' => Mage::helper('catalog')->__('Export to CSV'),
                'url'   => $this->getUrl('*/*/massExport', array('_current'=>true)),
            ));

现在您必须在产品控制器中实现此新操作(app / code / core / Mage / Adminhtml / controllers / Catalog / ProductController.php):

public function massExportAction()
    {
        $productIds = $this->getRequest()->getParam('product');
        if (!is_array($productIds)) {
            $this->_getSession()->addError($this->__('Please select product(s).'));
            $this->_redirect('*/*/index');
        }
        else {
            //write headers to the csv file
            $content = "id,name,url,sku\n";
            try {
                foreach ($productIds as $productId) {
                    $product = Mage::getSingleton('catalog/product')->load($productId);
                    $content .= "\"{$product->getId()}\",\"{$product->getName()}\",\"{$product->getProductUrl()}\",\"{$product->getSku()}\"\n";
                }
            } catch (Exception $e) {
                $this->_getSession()->addError($e->getMessage());
                $this->_redirect('*/*/index');
            }
            $this->_prepareDownloadResponse('export.csv', $content, 'text/csv');
        }

    }

代码主要是从massDeleteAction复制的,但不应删除应添加到$ content变量的产品。在完成csv导出的内容创建后(您可能需要向其中添加其他字段),您需要调用控制器类的_prepareDownloadResponse方法。就是这样,你有自定义出口!

最后一点,一旦您对更改感到满意,请记住将它们移动到您的本地代码池,以便您的magento安装保持更新防护:)