我需要第二双眼睛.每当其中一个条件(if或elsif)为真时,我就会得到一个额外的换行符.我不希望这样.
use strict;
use warnings;
use autodie;
use feature 'say';
my $filename = 'rr.txt';
open my $fh, '<', $filename;
while (<$fh>) {
my ($last_name, $first_name, $country) = split /[,\|]/, $_;
my $middle_name;
$country =~ s/^\(//;
$country =~ s/\)$//;
say "Last Name: $last_name";
say "First Name: $first_name";
say "Country: $country";
if ($first_name =~ /\w\s(\w+)/) {
$middle_name = $1;
say "Middle Name: $1";
} elsif ($first_name =~ /\w\-(\w+)/) {
$middle_name = $1;
say "Middle Name: $1";
}
}
Run Code Online (Sandbox Code Playgroud)
该文件如下所示:
Reid, Matt|(AUS)
Samper-Montana, Jordi|(ESP)
Krajonovic, Filip|(SRB)
Jones, Greg Luke|(AUS)
Burquier, Gregoire|(FRA)
Mandol, David|(ARG)
Daniel Llosa, Miguel Horpo|(DOM)
Run Code Online (Sandbox Code Playgroud)
每当输出一个中间名时,就会出现换行符.我不知道那是从哪里来的.使用print和追加换行也会发生同样的事情.
say在输出结尾添加换行符.您读取的国家/地区代码仍然附加换行符,因为您没有chomp输入行.因此,您获得双倍行距输出(来自国家之后的换行符,而不是中间名称之前的换行符).
修复:在行chomp;之前添加split.