php修改excel再上传,TP5 PHPExcel上传如何覆盖旧数据

该段代码实现了一个PHP函数,用于处理POST请求中的Excel文件上传。文件被移动到指定目录,然后使用PHPExcel库解析Excel内容。数据从第二行开始读取,并与数据库字段对应,插入到'test'表中。如果所有操作成功,文件会被删除,返回'导入成功';否则,提示'导入失败'。此外,还展示了获取数据库中'test'表记录数和分页查询的方法。
摘要由CSDN通过智能技术生成

bVbKcnD

如何覆盖重复的数据 求大神指点

public function dr()

{

if(request()->ispost()) {

header("content-type:text/html;charset=utf-8");

$filelink = request()->file('gt');

$info = $filelink->move(ROOT_PATH . '/public/' . DS . 'uploads/gt');

$file_name = ROOT_PATH . 'public' . DS . 'uploads/gt' . DS . $info->getsaveName();

//dump($file_name);die();

$fnarray=explode('.', $file_name);

$file_suffix = strtolower(array_pop($fnarray));

$allow_type = 'xlsx';

if ($file_suffix != $allow_type) {

$this->error('上传的格式不正确');

}

//判断导入表格后缀格式

$extension = strtolower(pathinfo($file_name, PATHINFO_EXTENSION));

import('phpexcel.PHPExcel', EXTEND_PATH);//extend是放置自定义或者其他类文件的。vendor目录是放置composer类库文件的。

//创建对象

$objReader = new \PHPExcel();

$objReader->exts = array('xlsx');

$objReader = \PHPExcel_IOFactory::createReader('Excel2007');

$objPHPExcel = \PHPExcel_IOFactory::load("{$file_name}");

$arr = $objPHPExcel->getsheet(0)->toArray();

//dump($arr);exit;

//加载文件内容,编码utf-8

$obj_PHPExcel = $objReader->load($file_name, $encode = 'utf-8');

//$obj_PHPExcel->setInputEncoding('utf-8');

//转换为数组格式

$excel_array = $obj_PHPExcel->getsheet(0)->toArray();

//array_shift($excel_array);//删除第一行

$i = 1;

$len = count($excel_array);

for ($i = 2; $i <= $len; $i++)//这个地方根据需要,一般第一行是名称,所以从第二行开始循环,也可以从第一行开始

{

//数据库字段和excel列相对应

$data["ch"] = $objPHPExcel->getActiveSheet()->getCell("D" . $i)->getValue();

$data["qdh"] = $objPHPExcel->getActiveSheet()->getCell("E" . $i)->getValue();

$data["ydh"] = $objPHPExcel->getActiveSheet()->getCell("F" . $i)->getValue();

$data["xh1"] = $objPHPExcel->getActiveSheet()->getCell("G" . $i)->getValue();

$data["xh2"] = $objPHPExcel->getActiveSheet()->getCell("H" . $i)->getValue();

$data["fz"] = $objPHPExcel->getActiveSheet()->getCell("I" . $i)->getValue();

$data["dz"] = $objPHPExcel->getActiveSheet()->getCell("J" . $i)->getValue();

$data["rxtime"] = $objPHPExcel->getActiveSheet()->getCell("K" . $i)->getValue();

$res = db('test')->insert($data);

unset($info);

}

if($res){

unlink($file_name);

$this->success('导入成功');

}else

{

$this->error('导入失败',url('index/index/index/'));

}

}

$list=db('test')->count('*');

$rs=db('test')->paginate(15);

$this->assign('rs',$rs);

$this->assign('list',$list);

return view();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值