中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Perl命令行的應用介紹

發布時間:2021-09-14 15:31:41 來源:億速云 閱讀:158 作者:chen 欄目:開發技術

這篇文章主要講解了“Perl命令行的應用介紹”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Perl命令行的應用介紹”吧!

Perl命令行應用介紹

Perl有很多命令行參數。通過它可以讓你的程序更簡練,并且可以寫出很多只有一行命令的perl。在這篇文章里我們來了解一些常用的命令行參數。

Perl命令行之安全網參數

有三個參數我認為可以起到“安全網”的作用,因為它們可以讓你避免犯錯,特別是當你在使用Perl嘗試一些特別聰明(或這愚蠢)的想法時,錯誤難免會發生。有經驗的Perl程序員常常使用這三個參數來提前找到錯誤所在。
-C是***個。這個參數編譯Perl程序但并不真正運行它。由此檢查所有語法錯誤。每次修改perl程序之后我都會立刻使用它來找到任何語法錯誤。
$perl-cprogram.pl
這保證了程序依然可以編譯。很顯然,當你輸入一小段代碼之后立即進行檢查,比起一下子輸入幾百行代碼然后開始debug要容易很多。
-W是第二個參數。它會提示你任何潛在的bug。Perl5.6.0之后的版本已經用usewarnings;替換了-w。你應該使用usewarnings因為它要比-w更靈活。
-T是第三個參數。它讓perl出于了taint模式中。在這個模式里,Perl會質疑任何程序外傳來的數據。例如,從命令行讀取,外部文件里讀取或是CGI程序里傳來的數據。這些數據在-T模式里都會被Tainted(污染)。Tainted數據不可以被用來和外部交互。例如使用在system調用和用作open的文件名。關于什么數據會被Tainted,請參閱perlsec文檔,那里有一個完整的列表。
要想使用Tainted的數據就必須untaint這個數據。untaint是通過正則表達式來實現的,關于taint本身的內容足夠寫一篇單獨的文章,所以這里我不會太多的講述taint模式。如果你要編寫的程序(例如CGI程序)需要從從用戶那里接受不可知的輸入,我推薦使有taint模式。
還有一個值得一提的參數是-d,它將讓Perl處于Debugger模式。這個話題內容非常多,我推薦閱讀文檔‘perldocperldebug’或RichardFoley的PerlDebuggerPocketReference一書.

Perl命令行之Command-LinePrograms

下面的幾個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命令行之ImplicitLoops

-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'$_="$.-$_"'filename
這種情況下我們就不需要要明確地調用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
雖然現在不是一行,但是你可以看出使用參數可以解決什么問題。

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命令行信息

Perl有大量的命令行參數,這篇文章只是列舉了最有用的一小部分。更詳細的信息請參考“perlrun”文檔。
打開Perl的taint模式
1、該程序的輸入數據來自外部數據源
2、該程序所調用sub-shell或者函數影響到該程序之外其它東西。
你可以用“-T”開關來打開Perl的taint模式。當打開taint模式時,Perl就會進行執行檢查以確保你的數據未被taint,如果不安全的使用了被taint的數據,就會發出嚴重錯誤。為了使你的數據不被taint,執行正則表達式來匹配數據并提取匹配部分。這樣,你就必須描述出你所期望的數據的內容以及格式,并只接受符合這一要求的數據。
例如,假設你期望收到一個單詞字符(wordcharacters,即字母數字以及下劃線)那么,下面的代碼通過一個正則表達式(它只通過全部由單詞字符組成字符串)會“蒸餾出”你的數據來:
if($data=~/^(\w+)$/){
$data=$1;
}else{
die”Error:tainteddatafound:$data\n”;
}

感謝各位的閱讀,以上就是“Perl命令行的應用介紹”的內容了,經過本文的學習后,相信大家對Perl命令行的應用介紹這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

岳西县| 聂拉木县| 辽阳县| 仪陇县| 隆子县| 江油市| 连城县| 应城市| 昌平区| 永兴县| 天台县| 安康市| 龙门县| 密云县| 卢氏县| 边坝县| 瑞安市| 长葛市| 兴隆县| 湖州市| 惠东县| 西昌市| 武邑县| 嵊州市| 方正县| 常山县| 毕节市| 洛南县| 个旧市| 万盛区| 大足县| 望江县| 中阳县| 辛集市| 萨嘎县| 凯里市| 齐河县| 凉城县| 盈江县| 宿州市| 玛曲县|