解析Perl命令行程序用法

本文和大家重点讨论一下Perl命令行程序的概念,主要包括隐式循环,数据分隔符和原位编辑等内容,相信通过本文的学习你一定会对Perl命令行程序有初步的认识。

Perl命令行程序

命令行程序

下面的几个Perl参数可以让短小的Perl程序很容易的在命令行上运行。-e可以让Perl代码在命令行上被编译器直接执行.例如,我们可以直接在命令行上运行"HelloWorld"程序而不用把它写称Perl程序。

$Perl
-e'print"HelloWorld\n"'
多个-e也可以同时使用,运行顺序根据它出现的位置.

$Perl
-e'print"Hello"$$'-e'print"World\n"'
象所有的Perl程序一样,只有程序的***一行不需要以;结尾.

虽然你也可以用-e来引用模块,但-M让它变得更容易.

$Perl
-MLWP::Simple-e'printhead"http://www.example.com"'
-M模块名和use模块名一样。有些模块有默认的模块导入,如果你不想导入它们,你可以使用-m。-m模块名和usemodule()一样,关闭了默认的导入。例如下面这个例子,因为head函数是默认导入,而使用-m时就不会执行,结果是没有输出。

$Perl
-mLWP::Simple-e'printhead"http://www.example.com"'
-m和-M有很多方便的语法来帮助你使用它们,你可以在=后面列出对use的各种参数。

$Perl
-MCGI=:standard-e'printheader'
在这里,CGI.pm的:standard被引入,header函数因此可以使用。要引入多个参数可以通过使用引号和逗号。

$Perl
-MCGI='header,start_html'-e'printheader,start_html'
这里我们引入了header和start_html函数。

Perl命令行程序之隐式循环

-n和-p增加了循环的功能,使你可以一行一行来处理文件.

$Perl
-n-e'somecode'file1
这与下面的程序一样.

LINE:
while(<>){
#yourcodegoeshere
}
注意:<>打开命令行里的文件,一行行的读取。每一行将缺省保存在$_

$Perl
-n-e'print"$.-$_"'file
上面的这一行可以写成

LINE:
while(<>){
print"$.-$_"
}
输出当前行数$.和当前行$_.-p可以让上面的程序变得更容易.-p会输出$_的内容,就像这样:

LINE:
while(<>){
#yourcodegoeshere
}continue{
printordie"-pdestination:$!\n"$$
}
continue在这里保证print在每次循环都会被调用。
使用-p,我们的打印行数程序可以改为
$Perl

-p-e'$_="$.-$_"'
这种情况下我们就不需要要明确地调用print函数了,因为-p选项已经调用了它。

注意,LINE:标签可以让我们直接跳到下一个输入记录,而不管你进入了多少层循环。使用nextLINE。

$Perl
-n-e'nextLINEunless/pattern/;print$_'
当然,也可以这样写:

$Perl
-n-e'printunless/pattern/'
在更复杂的情况里,nextLINE可以让你的代码更容易理解。

如果想在循环的前后做些处理,可以使用BEGIN或ENDblock.下面的这一行代码可以计算text文件里的字数。

$Perl
-ne'END{print$t}@w=/(\w+)/g;$t+=@w'file.txt
每一行所有匹配的字放入数组@w,然后把@w的元素数目递加到$t。ENDblock里的print***输出文件总字数。

还有两个参数可以让这个程序变得更简单。-a打开自动分离(split)模式。空格是缺省的分离号。输入根据分离号被分离然后放入缺省数组@F。由此,我们可以把上面的程序改写为

$Perl
-ane'END{print$x}$x+=@F'file.txt
你也可以通过-F把缺省的分离号改为你想要的.例如把分离号定为非字符:

$Perl
-F'\W'-ane'END{print$x}$x+=@F'file.txt
下面通过Unixpassword文件来介绍一个复杂的例子。Unixpassword是文本文件,每一行是一个用户记录,由冒号:分离。第?行是用户的登录shell路径。我们可以得出每一个不同shell路径被多少个用户使用:

$Perl
-F':'-ane'$s{$F[6]}++;'\
>-e'END{print"$_:$s{$_}"forkeys%s}'/etc/passwd
虽然现在不是一行,但是你可以看出使用参数可以解决什么问题。#p#

Perl命令行程序之数据分隔符

我以前的文章里提到过$/和$\--输入,输出分隔号。$/用来分隔从文件句柄里读出的数据,缺省$/分隔号是\n,这样每次从文件句柄里就会一行行的读取。$\缺省是空字符,用来自动加到要print的数据尾端。这就是为什么很多时候print都要在末尾加上\n。

$/和$\可与-n-p一起使用。在命令行上相对应为-0(零)和-l(这是L)。-0后面可以跟一个16进制或8进制数值,这个值用来赋给$/。-00打开段落模式,-0777打开slurp模式(即可以一次把整个文件读入),这与把$/设为空字符和undef一样效果。

单独使用-l有两个效果,***自动chomp输入分隔号,第二把$/值付给$\(这样print的时候就会自动在末尾加\n)

我个人常常使用-l参数,用来给每一个输出加\n.例如

$Perl

-le'print"HelloWorld"'

Perl命令行程序之原位编辑

使用已有的参数我们可以写出很有效的命令行程序.常见的UnixI/O重定向:

$Perl

-pe'somecode'output.txt
这个程序从input.txt读取数据,然后做一些处理再输出到output.txt.你当然也可以把输出重定向到同一个文件里.

上面的程序可以通过-i参数做的更简单些。-i把源文件更名然后从这个更名的源文件里读取。***把处理后的数据写入源文件。如果-i后跟有其他字符串,这个字符串与源文件名合成后来生成一个新的文件名。此文件会被用来储存原始文件以免被-i参数覆盖。

这个例子把所有php字符替换为Perl:

$Perl

-i-pe's/\bPHP\b/Perl/g'file.txt
程序读取文件的每一行,然后替换字符,处理后的数据重新写入(即覆盖)源文件.如果不想覆盖源文件,可以使用

$Perl

-i.bak-pe's/\bPHP\b/Perl/g'file.txt
这里处理过的数据写入file.txt,file.txt.bak是源文件的备份.

网站标题:解析Perl命令行程序用法
网页地址:http://www.csdahua.cn/qtweb/news26/476926.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网