在上一教程中,我们讨论了如何实现导入工具,在其中创建了导入按钮及其前端模板。 今天,我们将学习如何将大量数据从计算机直接导入OpenCart系统。
让我们首先考虑层次结构。 在上一教程中,我们实现了导出工具,该工具允许用户下载CSV表格并根据需要进行替换。 之后,我们实现了导入工具,该工具允许用户上传/导入已编辑的文件/数据。 以前我们实现了布局。 在本文中,我们将实现功能。
1.控制器文件
在上一个教程中,我们创建了一个控制器,该控制器将我们推送到上载表单的布局。 在布局的视图文件中,我们有一个上传输入,用户可以在其中上传CSV,如下所示:
- 导航到
admin/controller/catalog/product.php
。 - 找到我们在上一个教程中创建的
importCSV()
函数。
- 在其后放置
if (($this->request->server['REQUEST_METHOD'] == 'POST') ) {}
,以确保仅在提交上述表单后才执行代码部分。 - 在上面的代码块中,我们将添加下面逐步说明的代码。
1.1获取文件
以下代码打开提交的CSV文件,并将其作为只读处理。
<?php
$file = $_FILES['csv']['tmp_name'];
$handle = fopen($file,"r");
?>
1.2遍历每条记录
现在,我们需要遍历CSV的每一行并保存到数据库中。 在这方面,我们将遍历记录并相应地保存它们。
<?php
while ($data = fgetcsv($handle,1000,",","'")) // parses the line it reads for fields in CSV format and returns an array containing the fields read.
{
if ($data[0]!='') // if column 1 is not empty
{
$this->model_catalog_product->importCsvData($data); // parse the data to model
}
else
{
// in case of errors, put debug code here
}
}
?>
1.3重定向
导入完成后,必须将用户重定向,因此以下代码将用户重定向到表单并给出成功消息。
<?php
$this->session->data['success'] = 'CSV Successfully Imported!'; //success message
$this->redirect($this->url->link('catalog/product', 'token=' . $this->session->data['token'] . $url, 'SSL')); //redirected to the product page
?>
到目前为止,我们已经创建了一个仅上传CSV的函数,逐行读取其数据并将其解析到模型中。 现在,我们需要创建一个在控制器代码中定义的模型,该模型负责将解析的数据保存到db中。
2.模型文件
- 导航到
admin/model/catalog/product.php
。 - 在此处创建一个名为
importCsvData($data)
的公共函数。 - 在模型函数内部,我们将添加此代码,其中包含一些用于保存数据的查询。
<?php
$product_id = $data[0];
$model = $data[1];
$name = $data[2];
$quantity = $data[3];
if($product_id!='')
{
$query = $this->db->query("UPDATE `".DB_PREFIX."product` SET model='".$model."',quantity='".(int)$quantity."' WHERE product_id='".$product_id."'");//updating product quantity & its model
if($name)
{
$query = $this->db->query("UPDATE `".DB_PREFIX."product_description` SET name='".$this->db->escape($name)."' WHERE product_id='".$product_id."'"); // update the name of the product
}
}
?>
结论
因此,今天的教程都是关于为Export / Import系统提供完整的解决方案。 我们提供了这样一种解决方案,用户可以在其中编辑/更新其数据。 该解决方案也非常易于使用和实施。 期待您的反馈。 随时在下面发表评论或查询。 谢谢!
翻译自: https://code.tutsplus.com/tutorials/building-a-product-csv-import-tool-in-opencart-part-2--cms-24503