我正在使用PHPExcel实现一些导出功能。
由于PHP可以自动增加字母,因此一直可以正常工作,但是尝试减少它时却遇到了问题。
我可以递减$decremented = chr(ord($someChar) - 1);
这样的单个字符,但不能在2个字符上使用(例如'AA','BB',..等)
有什么办法可以减少两个字符?就像'ZZ'->'ZX','AA'->'Z'
任何帮助或想法都将不胜感激!
答案 0 :(得分:2)
这是一个递减函数,将为您工作:
function decrement($str) {
$index = strlen($str)-1;
$ord = ord($str[$index]);
if ($ord > 65) {
// The final character is still greater than A, decrement
return substr($str, 0, $index) . chr($ord-1);
}
if ($index > 0) {
// Strip the final 2 characters and append a Z
return substr($str, 0, $index-1) . 'Z';
}
// Can't be decremented
return false;
}
答案 1 :(得分:1)
有人为此here写了一个函数。
function decrementLetter($char) {
$len = strlen($char);
// last character is A or a
if(ord($char[$len - 1]) === 65 || ord($char[$len - 1]) === 97){
if($len === 1){ // one character left
return null;
}
else{ // 'ABA'--; => 'AAZ'; recursive call
$char = decrementLetter(substr($char, 0, -1)).'Z';
}
}
else{
$char[$len - 1] = chr(ord($char[$len - 1]) - 1);
}
return $char;
}