$str = 'a';
echo ++$str; // prints 'b'
$str = 'z';
echo ++$str; // prints 'aa'
在excel文件中获取下一个列名非常有用。
但是如果我使用类似的代码使用 - 运算符来获取前一个字母,那么它就不起作用了:
$str = 'b';
echo --$str; // prints 'b' but I need 'a'
$str = 'aa';
echo --$str; // prints 'aa' but I need 'z'
同样可以获得上一封信的解决方案是什么? 可能是因为它不起作用的原因是什么?
答案 0 :(得分:6)
$str='z';
echo chr(ord($str)-1); //y
注意:这不是a-z
的循环。需要为此添加规则
<强> Fiddle 强>
修改强> 此编辑涵盖了excel示例中的特殊要求。虽然它的代码有点长。
//Step 1: Build your range; We cant just go about every character in every language.
$x='a';
while($x!='zz') // of course you can take that to zzz or beyond etc
{
$values[]=$x++; // A simple range() call will not work for multiple characters
}
$values[]=$x; // Now this array contains range `a - zz`
//Step 2: Provide reference
$str='ab';
//Step 3: Move next or back
echo $values[array_search(strtolower($str),$values)-1]; // Previous = aa
echo $values[array_search(strtolower($str),$values)+1]; // Next = ac
<强> Fiddle 强>
答案 1 :(得分:0)
使用数组:
$cla=array('A', 'B', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O',
'P', 'R', 'S', 'Š', 'Z', 'Ž', 'T', 'U', 'V', 'Õ', 'Ä', 'Ö', 'Ü');
$direction = -1;
$element = 'Ü';
$element2 = $cla[((array_search($element,$cla)+count($cla)+$direction)%count($cla))];
答案 2 :(得分:-1)
我可以这样解决。 如何? 缺点是它现在只能处理大写。 还有一些工作可以解决这个问题。
<?php
function get_previous_letter($string){
$last = substr($string, -1);
$part=substr($string, 0, -1);
if(strtoupper($last)=='A'){
$l = substr($part, -1);
if($l=='A'){
return substr($part, 0, -1)."Z";
}
return $part.chr(ord($l)-1);
}else{
return $part.chr(ord($last)-1);
}
}
echo get_previous_letter("AAAAAA");
?>