PHP中的去重方法详解和文件下载
程序员文章站
2022-05-28 10:00:55
...
本文主要和大家分享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']."学号已经存在"."<br>"; }else{ $arrno[]=$row['no']; $arr[]=$row; // dump($arr); // exit; echo $row['no']."学号已经导入"."<br>"; } 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(); } }
相关推荐:
以上就是PHP中的去重方法详解和文件下载的详细内容,更多请关注其它相关文章!
上一篇: 一个学生的多门课的关联表查询?
下一篇: 刚参加工作的新手,求指导
推荐阅读
-
详解PHP的Yii框架中组件行为的属性注入和方法注入
-
Java8利用stream的distinct()方法对list集合中的对象去重和抽取属性去重
-
python实现去除下载电影和电视剧文件名中的多余字符的方法
-
Java8利用stream的distinct()方法对list集合中的对象去重和抽取属性去重
-
php获取CSS文件中图片地址并下载到本地的方法
-
php做下载文件的实现代码及文件名中乱码解决方法
-
python实现去除下载电影和电视剧文件名中的多余字符的方法
-
PHP中防止直接访问或查看或下载config.php文件的方法
-
跨浏览器PHP下载文件名中的中文乱码问题解决方法
-
详解PHP多个进程配合redis的有序集合实现大文件去重