生成excel 数据的时候, 需要计算数据的列, 例如 1 -> A , 2->B, 27 -> AA, 现在做一个简单的小工具实现

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
<?php

function ItoA($i) {
    $i = intval($i);
    return strtoupper(chr($i+64));
}

function AtoI($s) {
    if ($s == '') {
        return 0;
    }
    $s = strtoupper($s);
    return ord($s) - 64;
}


// 数字转成 ABC
function IntToABC($i){
    $res = '';
    while (true) {
        $m = $i % 26;
        if ($m == 0) {
            $m = 26;
        }
        $res =  ItoA($m) . $res;
        $i = ($i - $m) / 26;

        if ($i <= 0) {
            break;
        }
    }
    return $res;
}

// ABC 转成数字
function ABCToInt($str) {
    if ($str == ''){
        return 0;
    }
    $res = 0;
    
    $j = 1;
    for ($i=strlen($str) -1; $i>=0; $i--){
        $cur = $str[$i];
        $res += AtoI($cur) * $j;
        $j = $j *  26;
    }
    return $res;
}

$example = [1,2,26,28,777,49,703];

foreach($example as $raw) {
    $str = IntToABC($raw);
    $i = ABCToInt($str);
    echo  "example: $raw > $str > $i " . PHP_EOL;
}

执行结果:

1
2
3
4
5
6
7
example: 1 > A > 1
example: 2 > B > 2
example: 26 > Z > 26
example: 28 > AB > 28
example: 777 > ACW > 777
example: 49 > AW > 49
example: 703 > AAA > 703