Thinkphp中的上傳檔案及如何去重
阿新 • • 發佈:2019-01-22
上傳檔案: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>";
}