这个问题类似于"dropping trailing '.0' from floats",但对于 Perl 并且小数点后的最大位数。
我正在寻找一种将数字转换为字符串格式的方法,删除任何多余的“0”,包括不只是小数点后。并且仍然具有最大数量的数字,例如 3
输入数据是浮点数。期望的输出:
0 -> 0
0.1 -> 0.1
0.11 -> 0.11
0.111 -> 0.111
0.1111111 -> 0.111
这个问题类似于"dropping trailing '.0' from floats",但对于 Perl 并且小数点后的最大位数。
我正在寻找一种将数字转换为字符串格式的方法,删除任何多余的“0”,包括不只是小数点后。并且仍然具有最大数量的数字,例如 3
输入数据是浮点数。期望的输出:
0 -> 0
0.1 -> 0.1
0.11 -> 0.11
0.111 -> 0.111
0.1111111 -> 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
您还可以使用Math::Round来执行此操作:
$ 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
您可以sprintf
与 结合使用eval
。
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);