phpexcel动态获取列

2022-10-11 20:32:15 171 0
魁首哥

本文实例讲述了php生成excel列名超过26列大于Z时的解决方法。具体分析如下:

我们生成excel都会使用phpExcel类,这里就来给大家介绍在生成excel列名超过26列大于Z时的解决办法,这是phpExcel类中的方法,今天查到了,记录一下备忘,代码如下:

phpexcel动态获取列

public static function stringFromColumnIndex($pColumnIndex = 0) 
{ 
 // Using a lookup cache adds a slight memory overhead, but boosts speed 
 // caching using a static within the method is faster than a class  static , 
 // though it's additional memory overhead 
 static $_indexCache = array(); 
 
  if  (!isset($_indexCache[$pColumnIndex])) { 
 // Determine column string 
 if ($pColumnIndex < 26) { 
 $_indexCache[$pColumnIndex] = chr(65 + $pColumnIndex); 
 } elseif ($pColumnIndex < 702) { 
 $_indexCache[$pColumnIndex] = chr(64 + ($pColumnIndex / 26)) . chr(65 + $pColumnIndex % 26); 
 } else {
 $_indexCache[$pColumnIndex] = chr(64 + (($pColumnIndex - 26) / 676)) . chr(65 + ((($pColumnIndex - 26) % 676) / 26)) . chr(65 + $pColumnIndex % 26); 
 } 
 } 
 return $_indexCache[$pColumnIndex]; 
}
 

将列的数字序号转成字母使用,代码如下:

PHPExcel_Cell::stringFromColumnIndex($i); // 从o开始
 

将列的字母转成数字序号使用,代码如下:

PHPExcel_Cell::columnIndexFromString('AA');
 

收藏
分享
海报
0 条评论
171
上一篇:苹果手机辨别是有锁机还是无锁机 教程 下一篇:多语言/货币/国际配送方式,可免费商用的开源跨境电商商城系统

本站已关闭游客评论,请登录或者注册后再评论吧~

忘记密码?

图形验证码