En Perl, comment puis-je limiter le nombre de places après la virgule, mais ont pas de zéros de suivi?
-
05-09-2019 - |
Question
Cette question est similaire à « laissant tomber de fuite » .0' des flotteurs » , mais pour Perl et avec un nombre maximum de chiffres après la virgule.
Je suis à la recherche d'un moyen de convertir des nombres au format de chaîne, laissant tomber toute redondance « 0 », y compris non seulement juste après la virgule. Et toujours avec un maximum de numérique, par exemple 3
Les données d'entrée sont des flotteurs. sortie souhaitée:
0 -> 0
0.1 -> 0.1
0.11 -> 0.11
0.111 -> 0.111
0.1111111 -> 0.111
La solution
Vous pouvez également utiliser Math :: Round de faire ceci:
$ 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
Autres conseils
Utilisez les éléments suivants directement:
my $s = sprintf('%.3f', $f);
$s =~ s/\.?0*$//;
print $s
... ou définir un sous-programme pour le faire de manière plus générique:
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";
Prints:
0
1
1.1
1.12
1.123
1.123
1.12
1.12345
Vous pouvez utiliser "sprintf" combiné avec "eval".
my $num = eval sprintf('%.3f', $raw_num);
Par exemple:
#!/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";
}
sorties:
0
1
1
0.1
0.1
0.11
0.111
0.111
0.111
Cela vous donnera la sortie de votre recherche,
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);