我正在使用sprintf()来获取具有一定精度的某些浮点数的格式化字符串。另外,我想添加前导零以使所有数字均匀。对整数执行此操作是pretty straight forward:
sprintf('%02d', 1);
这将导致01
。但是,对具有精度的浮点尝试相同的操作不起作用:
sprintf('%02.2f', 1);
收益率1.00
。
如何将前导零添加到浮点值?
答案 0 :(得分:24)
简答: sprintf('%05.2f', 1);
会提供所需的结果01.00
请注意%02
取代%05
的方式。
<强>解释强>
这forum post向我指出了正确的方向:第一个数字既不表示前导零的数量,也不表示小数分隔符左侧的总字符数,而是表示总字符数。结果字符串!
示例强>
sprintf('%02.2f', 1);
至少产生小数分隔符“.
”加上至少2个字符的精度。由于总共已有3个字符,因此开头的%02
无效。要获得所需的“2前导零”,需要为精度和小数分隔符添加3个字符,使其成为sprintf('%05.2f', 1);
部分代码
$num = 42.0815;
function printFloatWithLeadingZeros($num, $precision = 2, $leadingZeros = 0){
$decimalSeperator = ".";
$adjustedLeadingZeros = $leadingZeros + mb_strlen($decimalSeperator) + $precision;
$pattern = "%0{$adjustedLeadingZeros}{$decimalSeperator}{$precision}f";
return sprintf($pattern,$num);
}
for($i = 0; $i <= 6; $i++){
echo "$i max. leading zeros on $num = ".printFloatWithLeadingZeros($num,2,$i)."\n";
}
<强>输出强>
0 max. leading zeros on 42.0815 = 42.08
1 max. leading zeros on 42.0815 = 42.08
2 max. leading zeros on 42.0815 = 42.08
3 max. leading zeros on 42.0815 = 042.08
4 max. leading zeros on 42.0815 = 0042.08
5 max. leading zeros on 42.0815 = 00042.08
6 max. leading zeros on 42.0815 = 000042.08
答案 1 :(得分:0)
保持简单
echo sprintf("%'06.2f", 32.1);
032.10