本文主要和大家分享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']."学号已经存在"."
";
}else{
$arrno[]=$row['no'];
$arr[]=$row;
// dump($arr);
// exit;
echo $row['no']."学号已经导入"."
";
}
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();
}
}
相关推荐: