Thinkphp中的上传文件及如何去重

上传文件:1.利用thinkphp中自带的upload方法上传文件,代码如下:

// 导入
    public function upload(){
        if(IS_GET){
            $this->display();
            exit;
        }
        $upload = new \Think\Upload();//实例化上传类
        $upload->maxSize = 0;//设置附件上传大小
        $upload->exts = array('csv');//设置附件上传类型
        $upload->rootPath = './Public/Upload/';//设置附件上传根目录
        $upload->savePath = '';//设置附件上传(子)目录
        // 上传文件
        $info = $upload->upload();
        if(!$info){//上传错误信息提示
            $this->error($upload->getError());
        }else{//上传成功
            $this->import($upload->rootPath.$info['file']['savepath'].$info['file']['savename']);
        }
    }

2.利用import方法将上传文件导入数据库中,并生成日志文件(用fwrite写入),(注意:写入日志文件中的换行符用该用\r\n)代码如下:

public function import($file){
        $encoding = detect_encoding($file);
        if($encoding != 'UTF-8'){
            $contens = file_get_contents($file);
            $contens = mb_convert_encoding($contens, 'utf-8',$encoding);
            file_put_contents($file, $contens);
        }
        $fp = fopen($file, 'r');
        if($fp){
            $fields = array('no','name','sex');
            $model = M('student');
            $arrNO = $model->getField('no',true); //查找数据库中的学号
            // dump($arrNO);
            // exit;
            $arr = array();

            $filename = './Public/Uploader/log.txt';//日志文件的目录
            $fpn = fopen($filename, 'w');
            
            while(($row = fgetcsv($fp,1000,","))!==false){
                // dump($row);
                // exit;
                $row = array_combine($fields,$row);
                // dump($row);
                // exit;
                $name = $row['name'];
                $row['py'] = SpGetPinyin($name);
                //去重
                if(in_array($row['no'],$arrNO)){    //查找导入文件中的学号是否存在
                    // $file = './Public/Uploader/log.txt';
                    $current .= $row['no']."该学号已存在\r\n";
                    // fwrite($fpn, $current);
                }else{
                    $arrNO[]=$row['no'];
                    $arr[]=$row;
                    // $file = './Public/Uploader/log.txt';
                    $current .= $row['no']."导入成功\r\n";
                    // fwrite($fpn, $current);
                }
                if(count($row)==1000){
                    $model->addAll($arr);
                    unset($arr);
                }
            }
            fwrite($fpn, $current);
            //file_put_contents($file, $current);   //将字符串写入文件
            $file_name = 'log.txt';   //下载文件名
            $file_dir = "./Public/Uploader/";    //下载文件存放目录
            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();
            }

            if(count($arr)>0){
                $model->addAll($arr);
            }
            $this->show('添加成功','utf8');
        }
    }

去除重复的方法:查询student中的所有学号($arrNo=$model->getField('no',true);),在用$arrNo与导入文件中的学号作比较(in_array($row['no'],$arrNo)),若存在则输出学号已存在,不存在则输出导入成功,并且继续向下执行,具体代码:

$fields = array('no','name','sex');
            $model = M('student');
            $arrNO = $model->getField('no',true); //查找数据库中的学号
            // dump($arrNO);
            // exit;
            $arr = array();
            while(($row = fgetcsv($fp,1000,","))!==false){
                // dump($row);
                // exit;
                $row = array_combine($fields,$row);
                // dump($row);
                // exit;
                //去重
                if(in_array($row['no'],$arrNO)){    //查找导入文件中的学号是否存在
                    echo $row['no']."该学号已存在"."<br>";
                }else{
                    $arrNO[]=$row['no'];
                    $arr[]=$row;
                    echo $row['no']."导入成功"."<br>";
                }






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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值