常用Perl命令行參數(shù)應(yīng)用分析
本文和大家重點(diǎn)討論一下Perl命令行應(yīng)用介紹,Perl有很多Perl命令行參數(shù).通過(guò)它,我們有機(jī)會(huì)寫(xiě)出更簡(jiǎn)單的程序.在這篇文章里我們來(lái)了解一些常用的參數(shù).
Perl命令行應(yīng)用介紹
Perl有很多Perl命令行參數(shù).通過(guò)它,我們有機(jī)會(huì)寫(xiě)出更簡(jiǎn)單的程序.在這篇文章里我們來(lái)了解一些常用的參數(shù).
SafetyNetOptions
在使用Perl嘗試一些聰明(或stupid)的想法時(shí),錯(cuò)誤難免會(huì)發(fā)生.有經(jīng)驗(yàn)的Perl程序員常常使用三個(gè)參數(shù)來(lái)提前找到錯(cuò)誤所在,
-C是***個(gè).這個(gè)參數(shù)編譯Perl程序但不會(huì)真正運(yùn)行它.由此檢查所有語(yǔ)法錯(cuò)誤.每次修改perl程序之后我都會(huì)立刻使用它來(lái)找到任何語(yǔ)法錯(cuò)誤.
CODE:
$perl-cprogram.pl
-W是第二個(gè)參數(shù).它會(huì)提示你任何潛在的問(wèn)題.Perl5.6.0之后的版本已經(jīng)用usewarnings;替換了-w.你應(yīng)該使用usewarnings因?yàn)樗?w更靈活.
-T是第三個(gè)參數(shù).它把perl放到了tain模式.在這個(gè)模式里,Perl會(huì)質(zhì)疑任何程序外傳來(lái)的數(shù)據(jù).例如,從Perl命令行讀取,外部文件里讀取或是CGI程序里傳來(lái)的數(shù)據(jù).這些數(shù)據(jù)在-T模式里都會(huì)被Tainted掉.
Tainted數(shù)據(jù)不可以被用來(lái)和外部交互.例如使用在system調(diào)用和用作open的文件名.perlsec文檔里有更多什么數(shù)據(jù)會(huì)被Tainted掉的例子.
要想使用Tainted的數(shù)據(jù)就需要untaint這個(gè)數(shù)據(jù).untaint是通過(guò)正則表達(dá)式來(lái)實(shí)現(xiàn).這里我不會(huì)太多的講述taint模式.如果你要編寫(xiě)的程序(例如CGI程序)需要從從用戶那里接受不可知的輸入,我推薦使有taint模式
-d,PerlDebugger,在這里值得一提但我們無(wú)法顧及,我推薦閱讀文檔'perldocperldebug'或RichardFoley的PerlDebuggerPocketReference一書(shū).
Command-LinePrograms
下面的幾個(gè)Perl參數(shù)可以讓短小的Perl程序運(yùn)行在Perl命令行.-e可以讓Perl程序在Perl命令行上運(yùn)行.例如,我們可以在Perl命令行上運(yùn)行"HelloWorld"程序而不用把它寫(xiě)入文件再運(yùn)行.
CODE:
$perl-e'print"HelloWorld\n"'
多個(gè)-e也可以同時(shí)使用,運(yùn)行順序根據(jù)它出現(xiàn)的位置.
CODE:
$perl-e'print"Hello";'-e'print"World\n"'
象所有的Perl程序一樣,只有程序的***一行不需要以;結(jié)尾.
雖然你也可以象通常一樣引用模塊,但-M讓它變得更容易.
CODE:
$perl-MLWP::Simple-e'printhead"http://www.example.com"'
-M模塊名和use模塊名一樣.如果不想引入模塊的缺省值,你可以使用-m.-m模塊名和use模塊名()一樣.例如下面這個(gè)例子,因?yàn)閔ead函數(shù)是缺省引入,而使用-m時(shí)就不會(huì),結(jié)果是沒(méi)有輸出.
CODE:
$perl-mLWP::Simple-e'printhead"http://www.example.com"'
-m和-M通過(guò)=來(lái)引入某個(gè)模塊的特別函數(shù).
CODE:
$perl-MCGI=:standard-e'printheader'
這里,CGI.pm的":standard"被引入,header函數(shù)因此可以使用.要引入多個(gè)參數(shù)可以通過(guò)使用引號(hào)和逗號(hào).
CODE:
$perl-MCGI='header,start_html'-e'printheader,start_html'
這里我們引入了header和start_html函數(shù).#p#
ImplicitLoops
-n和-p增加了循環(huán)的功能,使你可以一行一行來(lái)處理文件.
CODE:
$perl-n-e'somecode'file1
這與下面的程序一樣.
CODE:
LINE:
while(<>){
#yourcodegoeshere
}
<>;打開(kāi)Perl命令行里的文件,一行行的讀取.每一行缺省保存在$_
CODE:
$perl-n-e'print"$.-$_"'file
上面的這一行可以寫(xiě)成
CODE:
LINE:
while(<>){
print"$.-$_"
}
輸出當(dāng)前行數(shù)$.和當(dāng)前行$_.
-p可以讓上面的程序變得更容易.-p會(huì)輸出$_就像這樣
CODE:
LINE:
- while(<>){
- #yourcodegoeshere
- }continue{
- printordie"-pdestination:$!\n";
- }
continue在這里保證print在每次循環(huán)都會(huì)被調(diào)用.
使用-p,我們的打印行數(shù)程序可以改為
CODE:
$perl-p-e'$_="$.-$_"'
注意到那個(gè)LINE:標(biāo)簽?我們可以利用它來(lái)跳到下一個(gè)循環(huán).使用nextLINE
CODE:
$perl-n-e'nextLINEunless/pattern/;print$_'
如果想在循環(huán)的前后做些處理,可以使用BEGIN或ENDblock.下面的這一行計(jì)算文件里的字?jǐn)?shù).
CODE:
$perl-ne'END{print$t}@w=/(\w+)/g;$t+=@w'file.txt
每一行所有匹配的字放入數(shù)組@w,然后把@w的元素?cái)?shù)目遞加到$t.ENDblock里的print***輸出文件總字?jǐn)?shù).
還有兩個(gè)參數(shù)可以讓這個(gè)程序變得更簡(jiǎn)單.-a打開(kāi)自動(dòng)分離(split)模式.空格是缺省的分離號(hào).輸入根據(jù)分離號(hào)被分離然后放入缺省數(shù)組@F.由此,我們可以把上面的程序改寫(xiě)為
CODE:
$perl-ane'END{print$x}$x+=@F'file.txt
你也可以通過(guò)-F把缺省的分離號(hào)改為你想要的.例如把分離號(hào)定為非字符:
CODE:
$perl-F'\W'-ane'END{print$x}$x+=@F'file.txt
下面通過(guò)Unixpassword文件來(lái)介紹一個(gè)復(fù)雜的例子.Unixpassword是文本文件,每一行是一個(gè)用戶記錄,由冒號(hào):分離.第7行是用戶的登錄shell路徑.我們可以得出每一個(gè)不同shell路徑被多少個(gè)用戶使用:
CODE:
$perl-F':'-ane'$s{$F[6]}++;'\
>;-e'END{print"$_:$s{$_}"forkeys%s}'/etc/passwd
雖然現(xiàn)在不是一行,但是你可以看出使用參數(shù)可以解決什么問(wèn)題.#p#
RecordSeparators
以前我提到過(guò)$/和$\--輸入,輸出分隔號(hào).$/用來(lái)分隔從文件句柄里讀出的數(shù)據(jù),缺省$/分隔號(hào)是\n,這樣每次從文件句柄里就會(huì)一行行的讀取.$\缺省是空字符,用來(lái)自動(dòng)加到要print的數(shù)據(jù)尾端.這就是為什么很多時(shí)候print都要在末尾加上\n.
$/和$\可與-n-p一起使用.在Perl命令行上相對(duì)應(yīng)為-0(零)和-l(這是L).-0后面可以跟一個(gè)16進(jìn)制或8進(jìn)制數(shù)值,若是16進(jìn)制數(shù),需要使用前綴x.這個(gè)值用來(lái)付給$/.-0表示以null字符串作為分格符,-00打開(kāi)段落模式,-0777打開(kāi)slurp模式(即可以一次把整個(gè)文件讀入),這與把$/設(shè)為空字符和undef一樣效果.
單獨(dú)使用-l有兩個(gè)效果,***自動(dòng)chomp輸入分隔號(hào),第二把$/值付給$\(這樣print的時(shí)候就會(huì)自動(dòng)在末尾加\n)
我個(gè)人常常使用-l參數(shù),用來(lái)給每一個(gè)輸出加\n.例如
CODE:
$perl-le'print"HelloWorld"'
In-PlaceEditing
使用已有的參數(shù)我們可以寫(xiě)出很有效的Perl命令行程序.常見(jiàn)的UnixI/O重定向:
CODE:
$perl-pe'somecode'<input.txt>output.txt
這個(gè)程序從input.txt讀取數(shù)據(jù),然后做一些處理再輸出到output.txt.你當(dāng)然也可以把輸出重定向到同一個(gè)文件里.
上面的程序可以通過(guò)-i參數(shù)做的更簡(jiǎn)單些.
-i把源文件更名然后從這個(gè)更名的源文件里讀取.***把處理后的數(shù)據(jù)寫(xiě)入源文件.如果-i后跟有其他字符串,這個(gè)字符串與源文件名合成后來(lái)生成一個(gè)新的文件名.此文件會(huì)被用來(lái)儲(chǔ)存原始文件以免被-i參數(shù)覆蓋.
注意:使用-i參數(shù)后,文件將作為程序的標(biāo)準(zhǔn)輸出,所以必須使用-p參數(shù),或者程序里要包含print等輸出語(yǔ)法,不然文件將為空.
這個(gè)例子把所有php字符替換為perl:
CODE:
$perl-i-pe's/\bPHP\b/Perl/g'file.txt
程序讀取文件的每一行,然后替換字符,處理后的數(shù)據(jù)重新寫(xiě)入(即覆蓋)源文件.如果不想覆蓋源文件,可以使用
CODE:
$perl-i.bak-pe's/\bPHP\b/Perl/g'file.txt
這里處理過(guò)的數(shù)據(jù)寫(xiě)入file.txt,file.txt.bak是源文件的備份.
【編輯推薦】
- Perl命令行常見(jiàn)用法及技巧揭秘
- 常用Perl命令行參數(shù)應(yīng)用介紹
- 淺析Perl命令行應(yīng)用
- 五大常用Perl命令行參數(shù)應(yīng)用介紹
- 實(shí)例解析Perl命令行實(shí)用程序