phpexcel导入数据时超过26列怎么解决?

2025-04-07 06:10:08
推荐回答(2个)
回答1:

  生成excel都会使用phpExcel类,介绍在生成excel列名超过26列大于Z时的解决办法,这是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');

回答2:

for ($currentColumn = 'A'; $currentColumn <= $allColumn; $currentColumn++) {
echo $currentColumn, '
';
}
这个循环会自动以 AA,AB,....形式累加的