在Perl中,如何限制小数点之后的位置数量,但没有落后零?
-
05-09-2019 - |
题
这个问题类似于 “从浮子上掉落'.0', ,但对于Perl,十进制后的数字数量最多。
我正在寻找一种将数字转换为字符串格式的方法,从而删除了任何冗余的“ 0”,包括小数点后不仅仅是。并且仍然有最大数量的数字,例如3
输入数据是浮子。所需的输出:
0 -> 0
0.1 -> 0.1
0.11 -> 0.11
0.111 -> 0.111
0.1111111 -> 0.111
解决方案
您也可以使用 数学::圆 去做这个:
$ perl -MMath::Round=nearest -e 'print nearest(.001, 0.1), "\n"'
0.1
$ perl -MMath::Round=nearest -e 'print nearest(.001, 0.11111), "\n"'
0.111
其他提示
直接使用以下内容:
my $s = sprintf('%.3f', $f);
$s =~ s/\.?0*$//;
print $s
...或定义子例程以更一般地进行:
sub fstr {
my ($value,$precision) = @_;
$precision ||= 3;
my $s = sprintf("%.${precision}f", $value);
$s =~ s/\.?0*$//;
$s
}
print fstr(0) . "\n";
print fstr(1) . "\n";
print fstr(1.1) . "\n";
print fstr(1.12) . "\n";
print fstr(1.123) . "\n";
print fstr(1.12345) . "\n";
print fstr(1.12345, 2) . "\n";
print fstr(1.12345, 10) . "\n";
印刷:
0
1
1.1
1.12
1.123
1.123
1.12
1.12345
您可以将“ sprintf”与“评估”合并。
my $num = eval sprintf('%.3f', $raw_num);
例如:
#!/usr/bin/perl
my @num_array = (
0, 1, 1.0, 0.1, 0.10, 0.11, 0.111, 0.1110, 0.1111111
);
for my $raw_num (@num_array) {
my $num = eval sprintf('%.3f', $raw_num);
print $num . "\n";
}
输出:
0
1
1
0.1
0.1
0.11
0.111
0.111
0.111
这将为您提供您的输出,
sub dropTraillingZeros{
$_ = shift;
s/(\d*\.\d{3})(.*)/$1/;
s/(\d*\.\d)(00)/$1/;
s/(\d*\.\d{2})(0)/$1/;
print "$_\n";
}
dropTraillingZeros(0);
dropTraillingZeros(0.1);
dropTraillingZeros(0.11);
dropTraillingZeros(0.111);
dropTraillingZeros(0.11111111);
不隶属于 StackOverflow