自从我成为 Perling 以来已经有几个月了,但我完全不知道为什么会发生这种情况......
如果重要的话,我在 OSX 上。
我正在尝试转换文件中的行,例如
2011 年 8 月 3 日 01:00 PDT,1.11
进入标准输出行,如
XXX, 20120803, 0100, 千瓦时, 0.2809, A, YYY
由于我正在读取文件,因此我想chomp
在读入每一行之后。但是,当我 时chomp
,我发现我的打印变得一团糟。当我不chomp
打印时很好(除了额外的换行符......)。这里发生了什么?
while(<SOURCE>) {
chomp;
my @tokens = split(' |,'); # @tokens now [08/03/2011, 01:00, PDT, 1.11]
my $converted_date = convertDate($tokens[0]);
my $converted_time = convertTime($tokens[1]);
print<<EOF;
$XXX, $converted_date, $converted_time, KWH, $tokens[3], A, YYY
EOF
}
在chomp
那里调用,输出都混在一起了:
, A, YYY10803, 0100, 千瓦时, 1.11
如果没有chomp
调用,它至少会以正确的顺序打印,但有额外的新行:
XXX, 20110803, 0100, 千瓦时, 1.11 , 一, 年年
请注意,chomp
在那里,就像它覆盖了第一行“顶部”的换行符。我已经添加了$|=1;
自动刷新,但不知道这里还能做什么。
想法?并提前感谢....