生成数字的增量ID,上下字母

时间:2014-12-16 14:19:34

标签: php

如何在php混合数字,低位和高位字母中生成增量ID?

例如,我尝试过:

$hello = "aaa0";

for ($i=0; $i < 10000; $i++) { 
    echo $hello++;
    echo "<br>";
}

然后,它返回;

aaa0
aaa1
aaa2
...
aaa9
aab0
aab1

我想生成字符串:

aaa0
aaa1
aaa2
...
aaaa
aaab
aaac
...
aaaz
aaaA

从0到9的第一个数字,然后从a到z的字符,然后从A到Z的字符。每个位置字符应该在此范围内。

我该怎么做?

编辑:我希望字符串中的每个字符都在此范围内变化。我想从0到9,然后是a到z,然后是A到Z.当它结束时,char变为0,左边的char增加为1。例如:

0000
0001
0002
...
0009
000a
000b
...
000y
000z
000A
000B
...
000X
000Z
0010
0011
0012
....
0019
001a

3 个答案:

答案 0 :(得分:5)

这应该适合你:

<?php

    $hello = "aaa";

    //'aaa0' -> 'aaa9'
    for ($count = 0; $count <= 9; $count++)  
        echo $hello . $count . "<br />";
    //'aaaa' -> 'aaaz'
    foreach (range('a', 'z') as $char)
        echo $hello . $char . "<br />";
    //'aaaA' -> 'aaaZ'
    foreach (range('A', 'Z') as $char)
        echo $hello . $char . "<br />";

?>

修改

这仅适用于3位数字。内存不足后肯定会。

<?php

    $array = array();
    $maxLength = 3;
    $output = array();

    ini_set('memory_limit', '-1');
    $time_start = microtime(true);

    foreach(range(0, 9) as $number)
        $array[] = $number;
    foreach(range('a', 'z') as $char)
        $array[] = $char;
    foreach(range('A', 'Z') as $char)
        $array[] = $char;


    function everyCombination($array, $arrLength, $size, $perArr = array(), $pos = 0, &$found = array()) {
        if ($size == $pos) {
            $found[] = vsprintf("%s%s%s", $perArr);
            return;
        }

        for ($count = 0; $count < $arrLength; $count++) {
            $perArr[$pos] = $array[$count]; 
            everyCombination($array, $arrLength, $size, $perArr, $pos+1, $found); 
        }
        return $found;
    }

    $output = everyCombination($array, count($array), $maxLength);

    for($count = 0; $count < count($output); $count++)
        echo $output[$count] . "<br/>";

    echo "DONE!";
    $time_end = microtime(true);
    $time = $time_end - $time_start;
    echo  round($time,2) . " s";

?>

答案 1 :(得分:2)

使用0,1-9,a-z和A-Z是&#34; Base 62&#34;。在PHP中,从基数10转换到基数62非常容易。

<?php
echo base_convert(10123, 10,26), "\n";
// outputs: 'ep9'
echo base_convert('ep9', 26, 10), "\n";
// output 10123

答案 2 :(得分:0)

base_convert仅支持从base2到base36的转换。

如果内涵只是在base62(0-9 a-z A-Z)中递增,那么仅简单的算术增量(CPU的方式)就足够了。

我们将LSB(最低有效位/数字)加1,然后,如果溢出,则递增下一个LSB​​直到达到MSB(最高有效位/数字)。如果仍然有溢出,请在前面加1(而不是零)。

注意:前导零在算术中没有意义,因此000aa相同。如果您需要零填充,请稍后再添加。

注意::Base62中的数字顺序为0-9A-Z然后是a-z(与ASCII表相同)。如果要将其更改为0-9a-z,然后A-Z,则需要更改GMP字符串

const GMP = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";

function NextB62Digit(string $data): string {
    $i = strpos(GMP, $data);
    if (($i !== NULL) && $i != 61 /*strlen(GMP) - 1*/) {
        return GMP[$i + 1];
    } else {
        return "0";
    }
}

function Base62Increment(string $data): string {
    $out = "";
    $overflow = true;
    $i = strlen($data) - 1;
    while ($i > -1) {
        if ($overflow) {
            $thisDigit = NextB62Digit($data[$i]);
            if ($thisDigit !== '0'){
                $overflow = false;
            }
        } else {
            $thisDigit = $data[$i];
        }
        $out = $thisDigit . $out;
        $i--;
    }
    if ($overflow) {
        $out = '1' . $out;
    }
    return $out;
}

测试

echo "<pre>";
echo Base62Increment(   "1") . "\n"; //     2
echo Base62Increment(   "9") . "\n"; //     A
echo Base62Increment(   "z") . "\n"; //    10
echo Base62Increment("000a") . "\n"; //     b
echo Base62Increment("000Z") . "\n"; //     a
echo Base62Increment("aaaz") . "\n"; //  aab0
echo Base62Increment("zzzz") . "\n"; // 10000
echo "</pre>";