您现在的位置是: 首页 >  ThinkPHP8 ThinkPHP8

thinkphp6导入带图片的 Excel 表格

冬寂 2020-08-22 16:30:14 【ThinkPHP8】 4405人已围观

一、安装 phpoffice

代码仓库地址:https://packagist.org/packages/phpoffice/phpspreadsheet

或直接执行composer命令

composer require phpoffice/phpspreadsheet

出现下图所示,表示安装成功

安装不成功,可能是权限问题,检查composer.json和vendor,如果用centos的话不能用root用户,需新建用户执行composer命令

二、PHP代码

实现思路,先将excle上传保存到服务器,在读取excle处理数据和图片

//引入参考
use PhpOffice\PhpSpreadsheet\Cell\Coordinate;
use PhpOffice\PhpSpreadsheet\IOFactory;
use think\facade\Db;
use think\facade\Filesystem;
use think\facade\Request;
use think\facade\Session;
use think\response\Json;
use app\admin\model\Insurance as InsuranceModel;

/**
 * 上传**数据
 * Method upload_excel
 * @return void
 * author LIU 1278175138@qq.com
 * Time 2020/8/21 17:46
 * 版权 **集团
 */
Public function upload_excel(){
    if($this->app->request->isPost()) {
        $insuranceModel = new InsuranceModel();
        try {
            $file = $this->app->request->file('file');
            validate([
                'file' => [
                    'fileExt' => 'xlsx,xls'
                ]
            ],
                [
                    'file.fileExt' => '不支持的文件',
                ]
            )->check(['file' => $file]);

            $savename = Filesystem::disk('public')->putFile('excel', $file);

            $import_path = root_path() . 'public/upload/' . $savename;
            $spreadsheet = IOFactory::load($import_path);
            $sheet = $spreadsheet->getActiveSheet();
            $sheetData = $sheet->toArray();
            if (empty($sheetData) || !is_array($sheetData)) {
                $this->error('上传失败');
            }
            /*************图片单独处理开始*****************/
            $imageFilePath = root_path() . '/public/upload/excelimages/';//图片保存目录
            if (!file_exists($imageFilePath)) {
                mkdir("$imageFilePath", 0777, true);
            }
            //处理图片
            foreach ($sheet->getDrawingCollection() as $img) {
                list($startColumn, $startRow) = Coordinate::coordinateFromString($img->getCoordinates());//获取图片所在行和列
                $imageFileName = date('YmdHis') . mt_rand(1000, 9999);//图片名字随机生成
                switch ($img->getMimeType()) {
                    case 'image/jpg':
                    case 'image/jpeg':
                        $imageFileName .= '.jpg';
                        imagejpeg($img->getImageResource(), $imageFilePath . $imageFileName);
                        break;
                    case 'image/gif':
                        $imageFileName .= '.gif';
                        imagegif($img->getImageResource(), $imageFilePath . $imageFileName);
                        break;
                    case 'image/png':
                        $imageFileName .= '.png';
                        imagepng($img->getImageResource(), $imageFilePath . $imageFileName);
                        break;
                }

                $startColumn = $insuranceModel->ABCToDecimal($startColumn);//由于图片所在位置的列号为字母,转化为数字
                $sheetData[$startRow - 1][$startColumn] = '/upload/excelimages/' . $imageFileName;//把图片插入到数组中
            }
            /*************图片单独处理结束*****************/
            foreach ($sheetData as $key=>$vo){
                unset($sheetData[0]);
                if($vo[0] == '') unset($sheetData[$key]);
            }
            if($sheetData == []) return json(['code'=>202,'msg'=>'没有数据!']);
//到这里已经得到了导入的数据(数组),根据自己的业务逻辑,定义存储方法
            $res = $this->uploadExcel($sheetData);

            if ($res > 0) return json(['code'=>200,'msg'=>'成功导入' . $res . '条数据']);
            return json(['code'=>202,'msg'=>'导入失败!']);
        } catch (\think\exception\ValidateException $e) {
            return json(['code'=>202,'msg'=>$e->getMessage()]);
        }
    }
}

//上述的一个外链方法
/**
 * 上传文件列名转换为数字
 * Method ABC2decimal
 * @param $startColumn
 * @return int|string
 * author LIU 1278175138@qq.com
 * Time 2020/8/21 11:35
 * 版权 **集团
 */
Public function ABCToDecimal($startColumn){
    $arr = ['A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];
    foreach ($arr as $k=>$vo){
        if($vo == $startColumn){
            return $k;
        }
    }
}
很赞哦! ( 13 )

站点信息

  • 建站时间:2020-08-10
  • 文章统计100篇文章
  • 标签管理标签云
  • 统计数据百度统计
  • 微信公众号:扫描二维码,关注我