首頁 >後端開發 >php教程 >PHP中的去重方法詳解與檔案下載

PHP中的去重方法詳解與檔案下載

小云云
小云云原創
2018-03-29 09:30:501541瀏覽

本文主要和大家分享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[&#39;no&#39;]."学号已经存在"."<br>";
                }else{   
                    $arrno[]=$row[&#39;no&#39;];
                    $arr[]=$row;
                    // dump($arr);
                    // exit;
                    echo $row[&#39;no&#39;]."学号已经导入"."<br>";
                }
                if(count($arr)==1000){
                    $model->addAll($arr);
                    unset($arr);
                }
            }
            dump($arr);
            if(count($arr)>0){
                $model->addAll($arr);
            }
            $this->show(&#39;导入成功&#39;);
            // $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();
       }
    }

相關推薦:

PHP實作陣列去重的方法代碼

以上是PHP中的去重方法詳解與檔案下載的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn