PHP中的去重方法和文件下载。

在php中文件导入过程中,经常会遇到重复事件,那么就需要我们去重,然后进行下载。

1.思想

先设置一个存储主键数组,和一个空数组。解析文件,然后看要传入的数组中主键数组中是否存在,进行检测。设置附件上传目录。进行上传。

2.方法

如若数据库中本身就存在数据,很容易导入的数据重复,所以首先把主键放入一个主键数组中,再创建一个新一维数组,然后解析csv,如果解析出来的话,就应该把上面已经定义好的作为键名的数组和解析后的csv进行合并(array_combine)。生成一个新数组。那么,就应该判断要导入的数据中的主键和数据库本身的是否重复(in_array),如若重复,则显示这个学号已重复。如若没有,则把这个学号存储到主键数组中,并把这个数据内容存储到原本已定义的数组中。

3.代码

if($fp){
            $fields=array('no','name','sex');
            $model=M('student');
            $arrno=$model->getField('no',true);
            $arr=array();
            while(($row=fgetcsv($fp,1000,","))!==false){
            $row=array_combine($fields, $row);
                if(in_array($row['no'],$arrno)){
                  echo $row['no']."学号已经存在"."<br>";
                }else{   
                    $arrno[]=$row['no'];
                    $arr[]=$row;
                    // dump($arr);
                    // exit;
                    echo $row['no']."学号已经导入"."<br>";
                }
                if(count($arr)==1000){
                    $model->addAll($arr);
                    unset($arr);
                }
            }
            dump($arr);
            if(count($arr)>0){
                $model->addAll($arr);
            }
            $this->show('导入成功');
            // $this->download();

        }

下载

 public function download(){
       $file_name=$file;
       $file_dir="/Public/Download/";
       if(!file_exists($file_dir . $file_name)){
        echo "文件找不到";
        exit();
       }else{
        $file=fopen($file_dir, $file_name,"r");
        Header("Content-type:application/octet-stream");
        Header("Accept-Ranges:bytes");
        Header("Accept-Length:".filesize($file_dir.$file_name));
        Header("Content-Disposition:attachment;filename".$file_name);
        echo fread($file,filesize($file_dir.$file_name));
        fclose($file);
        exit();
       }
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值