PHP range() 从 A 到 ZZ?

新手上路,请多包涵

是否可以使用 PHP 获取从 A 到 ZZ* 的范围?

abc … aa … zx zy zz

对我来说这不起作用:

 range('A', 'ZZ');

它用于 PHPExcel,当它给出 BE 作为最高字段时,我会遍历所有列。在这种情况下,我只得到 A,B:

 range ('A', 'BE')

原文由 Ronn0 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 610
2 个回答

试试这个-(测试工作正常)

 function createColumnsArray($end_column, $first_letters = '')
{
  $columns = array();
  $length = strlen($end_column);
  $letters = range('A', 'Z');

  // Iterate over 26 letters.
  foreach ($letters as $letter) {
      // Paste the $first_letters before the next.
      $column = $first_letters . $letter;

      // Add the column to the final array.
      $columns[] = $column;

      // If it was the end column that was added, return the columns.
      if ($column == $end_column)
          return $columns;
  }

  // Add the column children.
  foreach ($columns as $column) {
      // Don't itterate if the $end_column was already set in a previous itteration.
      // Stop iterating if you've reached the maximum character length.
      if (!in_array($end_column, $columns) && strlen($column) < $length) {
          $new_columns = createColumnsArray($end_column, $column);
          // Merge the new columns which were created with the final columns array.
          $columns = array_merge($columns, $new_columns);
      }
  }

  return $columns;
}
echo "<pre>";
print_r( createColumnsArray('BZ'));

http://php.net/range 复制

原文由 Suresh Kamrushi 发布,翻译遵循 CC BY-SA 3.0 许可协议

利用 PHP 的“perl 风格”增加字符的能力

$letters = array();
$letter = 'A';
while ($letter !== 'AAA') {
    $letters[] = $letter++;
}

但您也可以使用简单的整数值,并利用 PHPExcel 的内置 PHPExcel_Cell::stringFromColumnIndex() 方法

编辑

从 PHP 5.5 开始,您还可以使用生成器来避免实际在内存中构建数组

function excelColumnRange($lower, $upper) {
    ++$upper;
    for ($i = $lower; $i !== $upper; ++$i) {
        yield $i;
    }
}

foreach (excelColumnRange('A', 'ZZ') as $value) {
    echo $value, PHP_EOL;
}

原文由 Mark Baker 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏