php读取excel 列数大于Z时读取不到

本文分享了处理Excel中超过26列时的读取难题,详细介绍了如何利用PHPExcel库将列号转换为数字,确保正确读取AA列及以后的数据。通过两种方案对比,提供了有效的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前写了一个需求,要求将后台上传的excel中的内容读取出来并入库,刚开始测试的时候没有问题,但是到线上开始上传的时候却报错,一开始百思不得其解,后来一点一点打断点调试的时候发现了问题
我原本的循环是将 i(初始值)设为’A’ , 读取文件最大列号 作为循环终止条件, 然后自加循环
因为我在本地测试的excel没有超过26列, 也就是在Z列之前 没有AA列及以后的情况, 所以测试一直都没有问题

当循环的时候AA的时候就没有办法识别,结果总是个0,然后开始上网找各种解决办法

总结如下

主要是利用excel扩展中的一个方法

PHPExcel_Cell::columnIndexFromString($allColumn)  //将列数转换为数字 列数大于Z的必须转  A->1  AA->27

具体代码如下

private function getExcelData()
    {
    	//获取excel文件
        $file = $_FILES['poily']['tmp_name'];
        //实例化excel处理类
        $PHPReader = new \PHPExcel_Reader_Excel2007();
        if (!$PHPReader->canRead($file)) {
            $PHPReader = new \PHPExcel_Reader_Excel5();
            if (!$PHPReader->canRead($file)) {
                return false;
            }
        }
        
        $PHPExcel = $PHPReader->load($file);
        $currentSheet = $PHPExcel->getSheet(0);//读取第一个工作表
        $allRow = $currentSheet->getHighestRow();//取得一共有多少行
        //这两段很重要
        $allColumn = $currentSheet->getHighestColumn();//取得最大的列号
        $allColumn = \PHPExcel_Cell::columnIndexFromString($allColumn);//将列数转换为数字 列数大于Z的必须转  A->1  AA->27
        
        $arr = [];

        //从第一行开始读 第一行为标题
        for ($currentRow = 1; $currentRow <= $allRow; $currentRow++) {
            //从第A列开始输出
            for ($currentColumn = 0; $currentColumn < $allColumn; $currentColumn++) {
               
                //plan 1
                //$strColumn  = \PHPExcel_Cell::stringFromColumnIndex($currentColumn);//将数字转换为字母  0->A  26->AA
                //$val = $currentSheet->getCell($strColumn.$currentRow)->getValue();

                //plan 2
                $val = $currentSheet->getCellByColumnAndRow($currentColumn, $currentRow)->getValue();

                //如果输出汉字有乱码,则需将输出内容用iconv函数进行编码转换,如下将gb2312编码转为utf-8编码输出 $arr[$currentRow][]=  iconv('utf-8','gb2312', $val)."\t";

                //将每列内容读取到数组中
                $arr[$currentRow][] = trim($val);
            }
        }

        //删除全部为空的行
        foreach ($arr as $key => $vals) {
            $tmp = '';
            foreach ($vals as $v) {
                $tmp .= $v;
            }
            if (!$tmp) unset($arr[$key]);
        }

        return $arr;
    }

最重要的地方就是将列号转换为数字 之前报错因为这里没有加
*
先将字母列数转换成对应数字
plan1 是将数字再转换成字母 然后拼接行号进行读取
plan2 是使用数字直接读取 不需要转换成字母

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值