默认状态下,很显然都是用\n来区分行,\n也被我们称作为换行符。

当读取序列时,按行来读取时,就是以换行符为标准。

读取的strawberry1.gb的文件内容如下:

LOCUS JX118024 460 bp DNA linear PLN 25-SEP-2012

DEFINITION Fragaria vesca subsp. americana RNA polymerase beta subunit (rpoC1)

gene, partial cds; plastid.

/

ACCESSION JX118024

//

VERSION JX118024.1 GI:402238751

KEYWORDS .

how

///

SOURCE plastid Fragaria vesca subsp. americana

第一个例子:默认情况

代码如下:

#!/bin/perl

my $record =' ';

open (DNAFILENAME,'f:\\perl\\strawberry1.gb')||die("can not open the file!");

$record = <DNAFILENAME>;

print $record;

这个就是没有任何的改动的情况,也就是默认的每次读取一行,结果如下:

F:\>perl\b.pl

LOCUS JX118024 460 bp DNA linear PLN 25-SEP-2012

如果我们对$/的值给改变一下,按照我们文件的特征,我们先改动为$/=“///\n;

代码如下:

#!/bin/perl

my $record =' ';

open (DNAFILENAME,'f:\\perl\\strawberry1.gb')||die("can not open the file!");

$/="///\n";

$record = <DNAFILENAME>;

print $record;

我们得到的结果如下:

F:\>perl\b.pl

LOCUS JX118024 460 bp DNA linear PLN 25-SEP-2012

DEFINITION Fragaria vesca subsp. americana RNA polymerase beta subunit (rpoC1)

gene, partial cds; plastid.

/

ACCESSION JX118024

//

VERSION JX118024.1 GI:402238751

KEYWORDS .

how

///

我们可以看到在这里,这一行是以///为分隔符的,///以上的整个部分都被看成一行。

同样不仅是字符可以作为分隔符,字母也可以,加入我们以how为分隔符,$/="how\n";

代码如下:

#!/bin/perl

my $record =' ';

open (DNAFILENAME,'f:\\perl\\strawberry1.gb')||die("can not open the file!");

$/="how\n";

$record = <DNAFILENAME>;

print $record;

结果如下:

C:\Documents and Settings\Administrator>f:perl\b.pl

LOCUS JX118024 460 bp DNA linear PLN 25-SEP-2012

DEFINITION Fragaria vesca subsp. americana RNA polymerase beta subunit (rpoC1)

gene, partial cds; plastid.

/

ACCESSION JX118024

//

VERSION JX118024.1 GI:402238751

KEYWORDS .

how

C:\Documents and Settings\Administrator>

同样我们也可以完全抛弃传统意义上的行,例如,我们以例子中的第五行的ACCESSION为分隔符:

代码如下:

#!/bin/perl

my $record =' ';

open (DNAFILENAME,'f:\\perl\\strawberry1.gb')||die("can not open the file!");

$/="ACCESSION";

$record = <DNAFILENAME>;

print $record;

结果如下:

F:\>perl\b.pl

LOCUS JX118024 460 bp DNA linear PLN 25-SEP-2012

DEFINITION Fragaria vesca subsp. americana RNA polymerase beta subunit (rpoC1)

gene, partial cds; plastid.

/

ACCESSION

F:\>

再来看一个例子:以/\n为分隔符:

代码如下:

#!/bin/perl

my $record =' ';

open (DNAFILENAME,'f:\\perl\\strawberry1.gb')||die("can not open the file!");

$/="/\n";

$record = <DNAFILENAME>;

print $record;

我们期望的结果应该是配匹到第四行以前的内容为一行,但是结果是否如此?

F:\>perl\b.pl

LOCUS JX118024 460 bp DNA linear PLN 25-SEP-2012

DEFINITION Fragaria vesca subsp. americana RNA polymerase beta subunit (rpoC1)

gene, partial cds; plastid.

/

ACCESSION JX118024

//

F:\>

为什么没有匹配到第一个/ 呢?

其实这里/这一行并不是仅仅有一个/,而是还有其他的成分在这里,我们把这一行完全删除,然后重新只输入一个/,我们再来匹配

F:\>perl\b.pl

LOCUS JX118024 460 bp DNA linear PLN 25-SEP-2012

DEFINITION Fragaria vesca subsp. americana RNA polymerase beta subunit (rpoC1)

gene, partial cds; plastid.

/

F:\>

这次就得到正确的结果了。

详细出处参考:http://www.jb51.net/article/34927.htm

【转】perl 变量 $/ 的用法解析 上下文为行模式时,$/ 定义以什么来区分行的更多相关文章

  1. perl 变量 $/ 的用法解析

    默认状态下,很显然都是用\n来区分行,\n也被我们称作为换行符.当读取序列时,按行来读取时,就是以换行符为标准. perl中"行"的概念就由$/决定. { $data = &quo ...

  2. extern "c"用法解析

    转自: extern "c"用法解析 - 简书 引言 C++保留了一部分过程式语言的特点,因而它可以定义不属于任何类的全局变量和函数.但是,C++毕竟是一种面向对象的程序设计语言, ...

  3. WordPress的have_posts()和the_post()用法解析

    原文地址:http://www.phpvar.com/archives/2316.html 网上找到一篇介绍WordPress的have_posts()和the_post()用法解析的文章,觉得不错! ...

  4. extern "C" 用法解析

    extern "c"用法解析 作者 作者Jason Ding ,链接http://www.jianshu.com/p/5d2eeeb93590 引言 C++保留了一部分过程式语言的 ...

  5. mysql group by 用法解析(详细)

    在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的 ...

  6. (转载)mysql group by 用法解析(详细)

    (转载)http://blog.tianya.cn/blogger/post_read.asp?BlogID=4221189&PostID=47881614 mysql distinct 去重 ...

  7. group by 用法解析

    group by 用法解析 group by语法可以根据给定数据列的每个成员对查询结果进行分组统计,最终得到一个分组汇总表. SELECT子句中的列名必须为分组列或列函数.列函数对于GROUP BY子 ...

  8. sql中的group by 和 having 用法解析

    转载博客:http://www.cnblogs.com/wang-123/archive/2012/01/05/2312676.html --sql中的group by 用法解析:-- Group B ...

  9. C/C++之extern "C"的用法解析

    extern "C"的用法解析 http://blog.sina.com.cn/u/494a1ebc010004g5 C++中extern “C”含义深层探索 1.引言 C++语言 ...

随机推荐

  1. swift 中异常的处理方法

    swift 中什么时候需要处理异常,在调用系统某个方法的时,该方法最后有一个throws 说明该方法会抛出异常,如果一个方法抛出异常,那么需要对该异常进行处理 swift 异常处理提供了三种方法 方式 ...

  2. Lamp下安装memcached

    1.先安装 libevent,再安装 Memcached主程序 # tar xf libevent-2.0.21-stable.tar.gz # cd libevent-2.0.21-stable # ...

  3. (转载)ConcurrentHashMap 原理

    集合是编程中最常用的数据结构.而谈到并发,几乎总是离不开集合这类高级数据结构的支持.比如两个线程需要同时访问一个中间临界区 (Queue),比如常会用缓存作为外部文件的副本(HashMap).这篇文章 ...

  4. Android混淆打包配置总结

    Android打包失败出现Proguard returned with error code 1. See console的错误 这个问题是由于代码混淆引起的,找不到引用包. 只需在你的proguar ...

  5. 【ANT】构建文件build.xml

    运行ant: ant 使用当前目录下的build.xml运行ant,指定缺省的target; ant –buildfile mybuild.xml 使用当前目录下的mybuild.xml运行ant,并 ...

  6. 使用Google Code和客户端TortoiseSVN 工具搭建一个在线源代码版本控制系统

    把代码放在Google Code里,客户端还是使用TortoiseSVN ,就可以很方便地在家里和办公室协调工作了,不用再用U盘把代码拷来拷去了. 搭建过程: 1.注册一个google账户:https ...

  7. oracle数据库创建表空间和表临时空间

    1:创建临时表空间 create temporary tablespace user_temp tempfile 'Q:\oracle\product\10.2.0\oradata\Test\xyrj ...

  8. 网易新闻RSS阅读器

    首先需要分析网易RSS订阅中心的网页布局情况. 网易RSS订阅中心:http://www.163.com/rss/ 你会发现RSS文件由一个<channel>元素及其子元素组成,除了频道本 ...

  9. TSQL基础(四) - 日期处理

    日期类型-DateTime DateTime是sql中最常用的日期类型. 存储大小为:8个字节: 日期范围:1753-01-01到9999-12-31: 精确度:3.33毫秒: 常用的日期函数 Get ...

  10. sql server 2008 查询语句的红色波浪线

    在 Microsoft sql server management studio 里点击“编辑”——“IntelliSense”——“刷新本地缓存” 就会发现红色波浪线没了(前提是你的代码没错)