Thinkphp实现文件上传以及去除重复数据
2018-03-29 17:42
316 查看
1.第一步 我们应该在控制器中写关于文件上传的方法 我在这里是用的upload()方法;
public function upload(){
if(IS_GET){
$this->display();
exit;
}
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 0 ;// 设置附件上传大小
//$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型
$upload->exts = array('csv');
$upload->rootPath = './Public/Upload/'; // 设置附件上传根目录
$upload->savePath = ''; // 设置附件上传(子)目录
// 上传文件
$info = $upload->upload();
if(!$info) {// 上传错误提示错误信息
$this->error($upload->getError());
}else{// 上传成功
// $this->success('上传成功!' . $info['file']['savepath'].$info['file']['savename']);
$file ='./Public/Upload/' . $info['file']['savepath'].$info['file']['savename'];
$this->import($file);
}
}
2.转换编码格式后,然后开始解析csv文件,判断这个csv文件中是否存在与数据库一样的数据,有重复我们就去掉重复数据。首先我们以只读的方式打开这个文件(fopen($file,'r')),我们用主键来判断是否有重复的,这里主键是no,所以我们先用getFie方法获取到原表中所有的no,把这些no数据存入到一个数组中,在用一个空数组存放没有重复的数据。 $fp = fopen($file,'r');//打开文件或者 URL
if($fp){
$fields = array('no','name','sex');
$model = M('student');
$arrNO = $model->getField('no',true);
$arr = array();
$str = array();
while (($row = fgetcsv($fp,1000,","))!==false) { //从文件指针中读入一行并解析 CSV 字段
$row = array_combine($fields, $row);//创建一个数组,用一个数组的值作为其键名,另一个数组的值作为其值
if(in_array($row['no'],$arrNO)){
$str[] = $row['no'] . '存在';
}else{
$arrNO[] = $row['no'];
$arr[] = $row;
$str[] = $row['no'] . '导入成功';
}
if(count($arr) == 1000){
$model->addAll($arr);
unset($arr);//释放给定的变量
}
}
if(count($arr)>0){
$model->addAll($arr);
}
2.
.
public function upload(){
if(IS_GET){
$this->display();
exit;
}
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 0 ;// 设置附件上传大小
//$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型
$upload->exts = array('csv');
$upload->rootPath = './Public/Upload/'; // 设置附件上传根目录
$upload->savePath = ''; // 设置附件上传(子)目录
// 上传文件
$info = $upload->upload();
if(!$info) {// 上传错误提示错误信息
$this->error($upload->getError());
}else{// 上传成功
// $this->success('上传成功!' . $info['file']['savepath'].$info['file']['savename']);
$file ='./Public/Upload/' . $info['file']['savepath'].$info['file']['savename'];
$this->import($file);
}
}
2.转换编码格式后,然后开始解析csv文件,判断这个csv文件中是否存在与数据库一样的数据,有重复我们就去掉重复数据。首先我们以只读的方式打开这个文件(fopen($file,'r')),我们用主键来判断是否有重复的,这里主键是no,所以我们先用getFie方法获取到原表中所有的no,把这些no数据存入到一个数组中,在用一个空数组存放没有重复的数据。 $fp = fopen($file,'r');//打开文件或者 URL
if($fp){
$fields = array('no','name','sex');
$model = M('student');
$arrNO = $model->getField('no',true);
$arr = array();
$str = array();
while (($row = fgetcsv($fp,1000,","))!==false) { //从文件指针中读入一行并解析 CSV 字段
$row = array_combine($fields, $row);//创建一个数组,用一个数组的值作为其键名,另一个数组的值作为其值
if(in_array($row['no'],$arrNO)){
$str[] = $row['no'] . '存在';
}else{
$arrNO[] = $row['no'];
$arr[] = $row;
$str[] = $row['no'] . '导入成功';
}
if(count($arr) == 1000){
$model->addAll($arr);
unset($arr);//释放给定的变量
}
}
if(count($arr)>0){
$model->addAll($arr);
}
2.
.
相关文章推荐
- Thinkphp中实现文件上传及去除重复数据
- Thinkphp中实现文件上传下载以及去除重复
- thinkphp文件上传并去除重复值,实现上传文件到日志文件中
- 用Thinkphp上传导入csv文件并去除重复数据
- SpringMVC实现页面和java模型的数据交互以及文件上传下载和数据校验
- ThinkPHP中文件上传和去除重复
- thinkphp文件上传 文件下载 id去除重复
- 怎样上传文件,去除重复数据,下载文件
- ThinkPHP上传文件时如何防止导入的数据重复
- 上传文件时如何去除重复的数据
- Node初学者入门,一本全面的NodeJS教程,微小的web框架,能实现文件上传功能以及数据解析功能
- 上传文件实现数据采集以及批量导入数据库实例
- 用thinkphp实现上传文件到数据库的功能并且文件内容不可以重复
- VB实现文件数据对SQL Server上传下载
- C#实现使用form上传Excel文件,导入Excel数据到SQL SERVER数据库
- java中如何实现文件打包上传以及自动解压
- HttpFileCollection 多文件上传的实现以及需要注意的事项
- 数据去重复(txt文件去重复,js实现)
- ajax实现文件上传以及后台servlet中的处理总结
- 在ASP.NET中实现多文件上传(以及添加节点的问题)(setAttribute())