PHP的floor()
和ceil()
对于将浮子舍入到其最近的整数中很有用。
但是,如果我们需要为给定的数字找到10个(数百,千等(的最高倍数怎么办?例如:
num_to_scale(538.9) // 500
num_to_scale(543123654.01234) // 5000000
尝试此代码,检查实时演示。您也可以参考此帖子。
$floor = floor($v);
return str_pad(substr($floor, 0, 1), strlen($floor), '0');
function num_to_scale($number) {
$multiple=1; $test=1;
for ($i=1; $test>=1; $i++) {
$factor = $multiple/10;
$test = $number/$multiple;
$multiple = $multiple*10;
$scale = floor($number/$factor)*$factor;
} return $scale;
}
或更简单:
function num_to_scale($n) {
$m=1; $t=1;
for ($i=1; $t>=1; $i++) {
$f=$m/10; $t=$n/$m; $m=$m*10; $s=floor($n/$f)*$f;
} return $s;
}
与辅助功能结合使用以将整数转换为文本字符串,我们可以轻松地执行类似的操作:
echo 'Over '.num_to_scale(5395206).' units sold.';
// Over five million units sold.
尝试以下:
function num_to_scale($number) {
$num = (int) floor($number);
$ln = strlen($num) - 1;
return (int) floor($num / pow(10, $ln)) * pow(10, $ln);
}
我的答案使用对数:
function num_to_scale($var) {
$nbDigits = (int)log($var,10);
return (int)($var/10**$nbDigits)*10**$nbDigits;
}