溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Perl命令行參數(shù)如何應(yīng)用

發(fā)布時(shí)間:2021-12-06 10:04:40 來源:億速云 閱讀:146 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了Perl命令行參數(shù)如何應(yīng)用,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

安全網(wǎng)參數(shù)

有三個(gè)參數(shù)我認(rèn)為可以起到“安全網(wǎng)”的作用,因?yàn)樗鼈兛梢宰屇惚苊夥稿e(cuò),特別是當(dāng)你在使用Perl嘗試一些特別聰明(或這愚蠢)的想法時(shí),錯(cuò)誤難免會(huì)發(fā)生。有經(jīng)驗(yàn)的Perl程序員常常使用這三個(gè)參數(shù)來提前找到錯(cuò)誤所在。
-C是***個(gè)。這個(gè)參數(shù)編譯Perl程序但并不真正運(yùn)行它。由此檢查所有語法錯(cuò)誤。每次修改perl程序之后我都會(huì)立刻使用它來找到任何語法錯(cuò)誤。

$perl-cprogram.pl

這保證了程序依然可以編譯。很顯然,當(dāng)你輸入一小段代碼之后立即進(jìn)行檢查,比起一下子輸入幾百行代碼然后開始debug要容易很多。
-W是第二個(gè)參數(shù)。它會(huì)提示你任何潛在的bug。Perl5.6.0之后的版本已經(jīng)用usewarnings;替換了-w。你應(yīng)該使用usewarnings因?yàn)樗?w更靈活。

-T是第三個(gè)參數(shù)。它讓perl出于了taint模式中。在這個(gè)模式里,Perl會(huì)質(zhì)疑任何程序外傳來的數(shù)據(jù)。例如,從Perl命令行讀取,外部文件里讀取或是CGI程序里傳來的數(shù)據(jù)。這些數(shù)據(jù)在-T模式里都會(huì)被Tainted(污染)。

Tainted數(shù)據(jù)不可以被用來和外部交互。例如使用在system調(diào)用和用作open的文件名。關(guān)于什么數(shù)據(jù)會(huì)被Tainted,請參閱perlsec文檔,那里有一個(gè)完整的列表。

要想使用Tainted的數(shù)據(jù)就必須untaint這個(gè)數(shù)據(jù)。untaint是通過正則表達(dá)式來實(shí)現(xiàn)的,關(guān)于taint本身的內(nèi)容足夠?qū)懸黄獑为?dú)的文章,所以這里我不會(huì)太多的講述taint模式。如果你要編寫的程序(例如CGI程序)需要從從用戶那里接受不可知的輸入,我推薦使有taint模式。

還有一個(gè)值得一提的參數(shù)是-d,它將讓Perl處于Debugger模式。這個(gè)話題內(nèi)容非常多,我推薦閱讀文檔‘perldocperldebug’或RichardFoley的PerlDebuggerPocketReference一書.

Command-LinePrograms

下面的幾個(gè)Perl參數(shù)可以讓短小的Perl程序很容易的在Perl命令行上運(yùn)行。-e可以讓Perl代碼在Perl命令行上被編譯器直接執(zhí)行.例如,我們可以直接在Perl命令行上運(yùn)行“HelloWorld”程序而不用把它寫稱Perl程序。
$perl-e'print"HelloWorld\n"'

多個(gè)-e也可以同時(shí)使用,運(yùn)行順序根據(jù)它出現(xiàn)的位置.
$perl-e'print"Hello";'-e'print"World\n"'

象所有的Perl程序一樣,只有程序的***一行不需要以;結(jié)尾.
雖然你也可以用-e來引用模塊,但-M讓它變得更容易.

$perl-MLWP::Simple-e'printhead"http://www.example.com"'

-M模塊名和use模塊名一樣。有些模塊有默認(rèn)的模塊導(dǎo)入,如果你不想導(dǎo)入它們,你可以使用-m。-m模塊名和usemodule()一樣,關(guān)閉了默認(rèn)的導(dǎo)入。例如下面這個(gè)例子,因?yàn)閔ead函數(shù)是默認(rèn)導(dǎo)入,而使用-m時(shí)就不會(huì)執(zhí)行,結(jié)果是沒有輸出。
$perl-mLWP::Simple-e'printhead"http://www.example.com"'

-m和-M有很多方便的語法來幫助你使用它們,你可以在=后面列出對use的各種參數(shù)。
$perl-MCGI=:standard-e'printheader'

在這里,CGI.pm的:standard被引入,header函數(shù)因此可以使用。要引入多個(gè)參數(shù)可以通過使用引號和逗號。
$perl-MCGI='header,start_html'-e'printheader,start_html'

這里我們引入了header和start_html函數(shù)。

ImplicitLoops

-n和-p增加了循環(huán)的功能,使你可以一行一行來處理文件.
$perl-n-e'somecode'file1

這與下面的程序一樣.
LINE:

while(<>){  #yourcodegoeshere  }

注意:<>打開Perl命令行里的文件,一行行的讀取。每一行將缺省保存在$_
$perl-n-e'print"$.-$_"'file

上面的這一行可以寫成LINE:while(<>){print”$.&ndash;$_”}輸出當(dāng)前行數(shù)$.和當(dāng)前行$_.


2006-12-2522:03回復(fù)
221.221.206.*2樓

-p可以讓上面的程序變得更容易.-p會(huì)輸出$_的內(nèi)容,就像這樣:

LINE:

while(<>){  #yourcodegoeshere  }continue{  printordie"-pdestination:$!\n";  }

continue在這里保證print在每次循環(huán)都會(huì)被調(diào)用。
使用-p,我們的打印行數(shù)程序可以改為

$perl-p-e'$_="$.-$_"'

這種情況下我們就不需要要明確地調(diào)用print函數(shù)了,因?yàn)?p選項(xiàng)已經(jīng)調(diào)用了它。
注意,LINE:標(biāo)簽可以讓我們直接跳到下一個(gè)輸入記錄,而不管你進(jìn)入了多少層循環(huán)。使用nextLINE。

$perl-n-e'nextLINEunless/pattern/;print$_'

當(dāng)然,也可以這樣寫:$perl-n-e'printunless/pattern/'

在更復(fù)雜的情況里,nextLINE可以讓你的代碼更容易理解。
如果想在循環(huán)的前后做些處理,可以使用BEGIN或ENDblock.下面的這一行代碼可以計(jì)算text文件里的字?jǐn)?shù)。

$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è)程序變得更簡單。-a打開自動(dòng)分離(split)模式??崭袷侨笔〉姆蛛x號。輸入根據(jù)分離號被分離然后放入缺省數(shù)組@F。由此,我們可以把上面的程序改寫為

$perl-ane'END{print$x}$x+=@F'file.txt

你也可以通過-F把缺省的分離號改為你想要的.例如把分離號定為非字符:
$perl-F'\W'-ane'END{print$x}$x+=@F'file.txt

下面通過Unixpassword文件來介紹一個(gè)復(fù)雜的例子。Unixpassword是文本文件,每一行是一個(gè)用戶記錄,由冒號:分離。第?行是用戶的登錄shell路徑。我們可以得出每一個(gè)不同shell路徑被多少個(gè)用戶使用:
$perl-F':'-ane'$s{$F[6]}++;'\
>-e'END{print"$_:$s{$_}"forkeys%s}'/etc/passwd

雖然現(xiàn)在不是一行,但是你可以看出使用參數(shù)可以解決什么問題。

數(shù)據(jù)分隔符

我以前的文章里提到過$/和$\&mdash;輸入,輸出分隔號。$/用來分隔從文件句柄里讀出的數(shù)據(jù),缺省$/分隔號是\n,這樣每次從文件句柄里就會(huì)一行行的讀取。$\缺省是空字符,用來自動(dòng)加到要print的數(shù)據(jù)尾端。這就是為什么很多時(shí)候print都要在末尾加上\n。
$/和$\可與-n-p一起使用。在Perl命令行上相對應(yīng)為-0(零)和-l(這是L)。-0后面可以跟一個(gè)16進(jìn)制或8進(jìn)制數(shù)值,這個(gè)值用來賦給$/。-00打開段落模式,-0777打開slurp模式(即可以一次把整個(gè)文件讀入),這與把$/設(shè)為空字符和undef一樣效果。

單獨(dú)使用-l有兩個(gè)效果,***自動(dòng)chomp輸入分隔號,第二把$/值付給$\(這樣print的時(shí)候就會(huì)自動(dòng)在末尾加\n)

我個(gè)人常常使用-l參數(shù),用來給每一個(gè)輸出加\n.例如

$perl-le'print"HelloWorld"'

原位編輯

使用已有的參數(shù)我們可以寫出很有效的Perl命令行程序.常見的UnixI/O重定向:
$perl-pe'somecode'<input.txt>output.txt

這個(gè)程序從input.txt讀取數(shù)據(jù),然后做一些處理再輸出到output.txt.你當(dāng)然也可以把輸出重定向到同一個(gè)文件里.上面的程序可以通過-i參數(shù)做的更簡單些。-i把源文件更名然后從這個(gè)更名的源文件里讀取。***把處理后的數(shù)據(jù)寫入源文件。如果-i后跟有其他字符串,這個(gè)字符串與源文件名合成后來生成一個(gè)新的文件名。此文件會(huì)被用來儲存原始文件以免被-i參數(shù)覆蓋。
這個(gè)例子把所有php字符替換為perl:

$perl-i-pe's/\bPHP\b/Perl/g'file.txt

程序讀取文件的每一行,然后替換字符,處理后的數(shù)據(jù)重新寫入(即覆蓋)源文件.如果不想覆蓋源文件,可以使用
$perl-i.bak-pe's/\bPHP\b/Perl/g'file.txt

這里處理過的數(shù)據(jù)寫入file.txt,file.txt.bak是源文件的備份.

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Perl命令行參數(shù)如何應(yīng)用”這篇文章對大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI