有一个容易的方法读入filehandles:用操作符。在标量内容下,它返回文件中的下一个记录,或者返回未定义出错信息。我们可以使用它来把一行读入到一个变量中:
$line=; die"Unexpectedend-of-file"unlessdefined$line; 在循环语句中,我们可以这样写: while(defined($record=)){#long-winded #$recordissettoeachrecordinthefile,oneatatime } |
因为要大量进行这样的工作,通常再进行一下简化,
把记录放到
Perl的经典用法:读入单个记录 - 凯旋网络
Perl的经典用法:读入单个记录
作者:凯旋网络来源:凯旋网络
本站关键字:凯旋网络 网站建设 网页设计 编程 Asp Php Css Html Xml .Net Access Mssql Mysql 脚本 代码
本站内刊登的所有文章及图片信息 版权归原作所有 如有侵害您的版权 请联系凯旋网络删除
中,而不是$record中:while(){ #
Perl的经典用法:读入单个记录 - 凯旋网络
Perl的经典用法:读入单个记录
作者:凯旋网络来源:凯旋网络
本站关键字:凯旋网络 网站建设 网页设计 编程 Asp Php Css Html Xml .Net Access Mssql Mysql 脚本 代码 本站内刊登的所有文章及图片信息 版权归原作所有 如有侵害您的版权 请联系凯旋网络删除
每次为文件中的一个记录 } 在Perl5.004_04中,我们可以这样做: while($record=){ #$record每次为文件中的一个记录 } |
defined()将自动加上,在Perl5.004_04以前的版本中,该命令给出一个警示。要了解所用的Perl版本,可在命令行下打入:
perl-v
一旦我们读出了一个记录,通常打算去掉记录分隔符,(缺省值为换行符字符):
chomp($record);
Perl4.0版本仅有chop()操作,去掉串的最后一个字符,不管该字符是什么。chomp()没有这么大的破坏性,如果有行分隔符存在,它仅去掉行分隔符。如果你打算去掉行分隔符,就用chomp()来代替chop()。