本文实例讲述了thinkphp5.1 框架导入/导出excel文件操作。分享给大家供大家参考,具体如下:
thinkphp5.1 导入excel文件
public function importExcel()
{
try {
//获取表格的大小,限制上传表格的大小
if ($_FILES['file']['size'] > 10 * 1024 * 1024) { //文件过大
log_debug($log_title . 'END === MSG:' . '文件过大');
parent::endBack(['state' => 0, 'msg' => '文件过大']);
}
//限制上传表格类型
$ext = substr(strrchr($_FILES['file']["name"], '.'), 1);
if ($ext != 'xls' && $ext != 'xlsx') {
log_debug($log_title . 'END === MSG:' . '文件格式不正确');
parent::endBack(['state' => 0, 'msg' => '上传文件必须为excel表格']);
}
//读取表格
$filename = $_FILES['file']['tmp_name'];
$reader = IOFactory::createReader('Xlsx'); //Xls,Xlsx都可读取
$canRead = $reader->canRead($filename);
if (!$canRead) {
log_debug($log_title . 'END,文件格式不正确,SQL:' . Db::name('')->getLastSql());
parent::endBack(['state' => 0, 'msg' => '文件格式不正确', 're_login' => false]);
}
$spreadsheet = $reader->load($filename); //载入excel表格
$worksheet = $spreadsheet->getActiveSheet(); //选中sheet表
$highestRow = $worksheet->getHighestRow(); // 总行数
// $highestColumn = $worksheet->getHighestColumn(); // 总列数
if (!(0 < $highestRow)) {
log_debug($log_title . 'END,文件内容空,SQL:' . Db::name('')->getLastSql());
parent::endBack(['state' => 0, 'msg' => '文件没有数据', 're_login' => false]);
}
//循环读取--有效判断
$sst_word_arr = []; //存放敏感词的数组
for ($row = 1; $row <= $highestRow; $row++) {
//取列数A列的数据
$tmp_word = $spreadsheet->getActiveSheet()->getCell('A' . $row)->getValue();
if ('' != trim($tmp_word) && null != $tmp_word) {
$sst_word_arr[] = $tmp_word;
break; //发现有效数据,直接退出,接下来插入数据
}
}
// $sst_word_arr = array_unique($sst_word_arr);
if (empty($sst_word_arr)) {
log_debug($log_title . 'END,文件无有效数据,SQL:' . Db::name('')->getLastSql());
parent::endBack(['state' => 0, 'msg' => '文件无有效数据', 're_login' => false]);
}
//判断和数据库操作
for ($row = 2; $row <= $highestRow; $row++) {
//取列数A列的数据
$tmp_old_car_num = $spreadsheet->getActiveSheet()->getCell('A' . $row)->getValue();
$car_num = trim($tmp_old_car_num);
if ('' != $car_num && null != $car_num) {
//数据库操作
}
}
}
$ret_arr = [
'state' => 1,
//返回数据
];
log_debug($log_title . 'END,SUCCESS');
parent::endBack($ret_arr);
} catch (\Exception $e) {
//
}
}
excel文件格式为:
thinkphp5.1 导出excel文件
namespase app\test;
use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
class test {
public function carNumsExport()
{
$log_title = '测试 => 车牌列表导出[' . __METHOD__ . '] ';
try {
$file_name = '《车牌列表》from y8zh - ' . $user_info['uid'] . '.xlsx';
$file_relative_path = parent::$module_name . DIRECTORY_SEPARATOR . 'fcb_car_nums' . DIRECTORY_SEPARATOR;
$file_path = parent::$api_file_root_path . $file_relative_path;
// 已生成过则直接返回
if (file_exists($file_path . $file_name)) {
$ret_arr = [
'state' => 1,
'download_url' => parent::$api_file_get_url . $file_relative_path . $file_name,
];
parent::endBack($ret_arr);
}
if (!is_dir($file_path)) {
mkdir($file_path, 0777, true);
}
$spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet();
//获取所有车牌号
$car_nums = Db::connect('db_config_yun')->name('vechicle')->column('DISTINCT number');
$i = 1;
$sheet->setCellValue('A' . $i, '车牌号')->getStyle('A' . $i)->getFont()->setBold(true);
$i++;
// 表内容
if (!empty($car_nums)) {
foreach ($car_nums as $k_c => $v_c) {
$sheet->setCellValue('A' . $i, $v_c);
$i++;
}
}
$writer = new Xlsx($spreadsheet);
$writer->save($file_path . $file_name);
$ret_arr = [
'state' => 1,
'download_url' => parent::$api_file_get_url . $file_relative_path . $file_name,
];
log_debug($log_title . 'END === DOWNLOAD_URL:' . $ret_arr['download_url']);
parent::endBack($ret_arr);
} catch (\Exception $e) {
//
}
}
}
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“thinkphp5.1 框架导入/导出excel文件操作示例”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2025年11月13日
2025年11月13日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]
