1. 程式人生 > >Thinkphp中的上傳檔案及如何去重

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>";
                }