在OpenCart中构建产品CSV导入工具:第2部分

在上一教程中,我们讨论了如何实现导入工具,在其中创建了导入按钮及其前端模板。 今天,我们将学习如何将大量数据从计算机直接导入OpenCart系统。

让我们首先考虑层次结构。 在上一教程中,我们实现了导出工具,该工具允许用户下载CSV表格并根据需要进行替换。 之后,我们实现了导入工具,该工具允许用户上传/导入已编辑的文件/数据。 以前我们实现了布局。 在本文中,我们将实现功能。

1.控制器文件

在上一个教程中,我们创建了一个控制器,该控制器将我们推送到上载表单的布局。 在布局的视图文件中,我们有一个上传输入,用户可以在其中上传CSV,如下所示:

导入CSV页面
  1. 导航到admin/controller/catalog/product.php
  2. 找到我们在上一个教程中创建的importCSV()函数。
  3. 在其后放置if (($this->request->server['REQUEST_METHOD'] == 'POST') ) {} ,以确保仅在提交上述表单后才执行代码部分。
  4. 在上面的代码块中,我们将添加下面逐步说明的代码。

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.模型文件

  1. 导航到admin/model/catalog/product.php
  2. 在此处创建一个名为importCsvData($data)的公共函数。
  3. 在模型函数内部,我们将添加此代码,其中包含一些用于保存数据的查询。
<?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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值