как сгенерировать pCoordinates для файлов Xlsx - PullRequest
1 голос
/ 14 апреля 2020

Я хочу сгенерировать координаты для этого

 $sheet->setCellValue($pCoordinate, $pValue);

a $ pCoodrinates - это буква, а затем число, например A1, B1, C1, то есть, например, первая строка, затем следующая строка - A2, B2, C2 и следующая строка с 3

Это код, который у меня есть прямо сейчас

class SpreadSheetHelper
{
    private static $alphabet = 'ABCDEFGHIJKLMNOPQRSTUYVWXYZ';

    public static function createSpreadSheet($data = []) {
        $spreadsheet = new Spreadsheet();
        $sheet       = $spreadsheet->getActiveSheet();
        foreach ($data as $rowIndex => $row) {
            foreach ($row as $columnIndex => $columnValue) {
                $pCoordinate = self::getAlphabetCoordinate($rowIndex, $columnIndex);
                $pValue = $columnValue;
                $sheet->setCellValue($pCoordinate, $pValue);
            }
        }

        return $spreadsheet;
    }


    private static function getAlphabetCoordinate($rowIndex, $columnIndex) {
        $letter = strtoupper(substr(self::$alphabet, $columnIndex, 1));
        $number = $rowIndex + 1;
        return "$letter$number";
    }
}

Как вы можете видеть, алфавит $ жестко запрограммирован и ограничен и достигает последнего буква должна начинаться с AA, AB, A C, AD, AE, AF, и это то, что я хочу сгенерировать. Есть идеи как это сделать?

1 Ответ

0 голосов
/ 14 апреля 2020

Вы можете воспользоваться ASCII-таблицей:

<code><?php
//Number of rows and columns
$rows = 3;
$cols = 40;

$pcoords = array();
for($current_row=1;$current_row<$rows+1;$current_row++) {
    $alpha_index = 65;
    $alpha_pref_index = 65;
    $alpha_count = 0;
    $pref_letter = '';

    for($current_col=0;$current_col<$cols;$current_col++) {
        $col_letter = chr($alpha_index);
        $pcoords[] = $pref_letter . $col_letter. $current_row;
        $alpha_count++;
        if ($alpha_count == 26) {
            $alpha_count = 0;
            $alpha_index = 65;
            $pref_letter = chr($alpha_pref_index);     
            $alpha_pref_index++;               
        }
        else {
            $alpha_index++;            
        }        
    }    
}

echo '<pre>';
print_r($pcoords);
echo '
';
...