3

自从我成为 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;自动刷新,但不知道这里还能做什么。

想法?并提前感谢....

4

2 回答 2

10

您输入的行以 CR LF 结尾。您只删除了 LF。一个简单的解决方案是使用以下内容而不是chomp

s/\s+\z//;

您还可以使用dos2unix命令行工具在将文件传递给 Perl 之前对其进行转换。

于 2012-05-24T14:14:08.560 回答
1

问题是你有 DOS 行尾并且运行在 Perl 的 Unix 版本上。

一种解决方案是使用PerlIO::eol. 您可能必须安装它,但程序中不需要use一行。

然后你可以写

binmode ':raw:eol(LF)', $filehandle;

之后,无论文件的格式或来源如何,读取的行都将以标准"\n".

于 2012-05-24T14:24:41.080 回答