首页    新闻    下载    文档    论坛     最新漏洞    黑客教程    数据库    搜索    小榕软件实验室怀旧版    星际争霸WEB版    最新IP准确查询   
名称: 密码:      忘记密码  马上注册
操作系统 :: linux

Linux下Perl的经典用法:读入单个记录


http://www.gipsky.com/
  有一个容易的方法读入filehandles:用 操作符。在标量内容下, 它返回文件中的下一个记录,或者返回未定义出错信息。我们可以使用它来把一行读 入到一个变量中:

  

  $line = ;

  

  die "Unexpected end-of-file" unless defined $line;

  

  在循环语句中,我们可以这样写:

  

  while (defined ($record = )) { # long-winded

  

  # $record is set to each record in the file, one at a time

  

  }

  

  因为要大量进行这样的工作,通常再进行一下简化,

  

  把记录放到$_ 中,而不是$record中:

  

  while () {

  

  # $_ 每次为文件中的一个记录

  

  }

  

  在Perl 5.004_04中,我们可以这样做:

  

  while ($record = ) {

  

  # $record 每次为文件中的一个记录

  

  }

  

  defined() 将自动加上,在Perl 5.004_04以前的版本中,该命令给出一个警示。 要了解所用的Perl版本,可在命令行下打入:

  

  perl -v

  

  一旦我们读出了一个记录,通常打算去掉记录分隔符,(缺省值为换行符字符):

  

  chomp($record);

  

  Perl 4.0版本仅有chop()操作,去掉串的最后一个字符, 不管该字符是什么。chomp() 没有这么大的破坏性,如果有行分隔符存在,它仅去掉行分隔符。如果你打算去掉行分隔符, 就用chomp() 来代替chop()。
<< 功能丰富的 Perl:用于系统管理 Perl的经典用法:用Sysopen()进行控制 >>
API:
gipsky.com& 安信网络
网友个人意见,不代表本站立场。对于发言内容,由发表者自负责任。

系统导航

 

Copyright © 2001-2010 安信网络. All Rights Reserved
京ICP备05056747号