perl 入門知識(1)

2022-03-21 04:12:51 字數 3927 閱讀 2809

《一》 語句及注釋:

perl 語句以分號(;)結尾,用 # 作為一行的注釋,沒有其它語言中那種跨行的注釋。**塊用大括號圍起來,這個和 c 類似,但這個大括號在有些地方是強制要求,如在 if ,for,do, while 等語句中,它不像其它語言一樣會用縮進來判斷塊。

《二》 變數: 標量(scalar) & 列表(list)

perl把簡單的資料型別,如字串,數字等「單數」的東西統稱為標量,與之相對的,就是「複數」的東西,如陣列。標量的宣告都是 $ 開始,如:  $str = "abc"。多個標量也可以放一處一起宣告:

($x, $y, $z) = (11, 22, "no");

而陣列的宣告則是以@開頭,如:@arr = ("abc","edf")。變數的宣告和很多其它指令碼語言一樣,不需要指明型別,直接宣告賦值就可以使用。如果只宣告但不賦值,perl 會預設給它賦值為:undef。

為了檢查乙個變數是否已被賦值,perl 提供了乙個操作符:defined,用於判斷乙個變數是否已經被賦值:

if( !defined( $myvar ) ) 

print "uninitialized variable";

《三》 字串

(1) 基本語法

在 perl 中,所有字串都是雙引號或單引號括起來的,如: "string"  'string'。這兩種方式在很多時候相同,不同的是當字串出現其它變數或轉義符號的時候,雙引號會將變數的內容展開,而單引號的不會,這和 shell script 是相似的,如:

$var = 234;

$str1 = "str1:$var";    # 列印出來得到-> str1:234

$str2 = 'str2:$var';     # 列印出來得到-> str2:$var

(2) 字串拼接

點號(.)用於把字串進行拼接,這個和其它一些語言直接把字串連在一起就行不一樣,要用點號把字串連起來,如:

$str = "abc"."efg";  # abcefg

這個用法,和 shell script , vim script 也是一致的。  

(3) 比較

這裡需要強調的,字串的比較要用:

而不要用== , >=  , <= ,這些符號是用來比較數值型別的。 

《四》 陣列

(1) 宣告

如前所說,陣列是乙個複數(plaural)形式的變數,它的宣告是以@開頭的,後面跟著小括號放入初始值:

@arr = (12,34,56);

同乙個陣列裡的元素型別不一定要一樣,下面的寫法也是合法的:

@arr = (12,"abc",'c');

當然,也可以宣告空陣列:

@arr = ();

宣告字串陣列時,可以用 q,qq,qw 系列操作符簡化操作。q 代表 quoted,  qw 代表: quoted word.

@arr = qq(abc);   # 等價於 ("abc")

@arr = qw(abc ef gg);   # 等價於("abc","ef","gg")

@arr = q(abc);    # 等價於('abc') 

由上看出 qq 與 qw 的區別就在於,qq 是將括號中的整個內容當成乙個整體加上雙引號,而 qw 是以空格為分隔,如上第二個例子,abc, ef, gg 分別被加上了雙引號,而 q 與 qq 相似。這幾個操作符的好處在於,當你想在字串加入轉義符號,引號等符號時,會方便很多。

qq(\abc)  eq  「\\abc"

qq("abc") eq 」\"abc\""

(2) 陣列訪問,插入

如果想訪問陣列裡的元素,就用中括號加下標的方法,和很多其它語言一樣,perl的陣列元素從0開始算:

print $arr[2];

有人可能注意到了,引用裡面元素的時候,又用了$,而不是@。這裡其實有乙個原則,用@時,是表示整個陣列,而引用其中的元素時,就用 $,後面將講到hash型別陣列,也是同樣的原則。上面是一次訪問乙個元素,如果需要取出 sub array(切片), 則應如下寫:

@sub_arr = @arr[1,4];

perl 中的陣列是沒有指定大小的,如果訪問了沒有定義的元素,就會返回 undef:

@arr = (1,2,3);

$ele = $arr[20]; # ele == undef

如果要往陣列中加入新元素,也可以直接用中括號+下標:

$arr[4] = 4; #如果不存在第4個元素就插入,存在就覆蓋。    

(3) 轉換

下面提乙個很體現 perl 風格的問題,前面說到,用@引用 乙個陣列時,表示對整個陣列的引用,但這種引用在不同場合下(context)是表示不同含義的:

@arr = ("abc", "ed");

print "arr: @arr" ;

上面的 print 會將 arr 中的元素乙個個的提取出來展開列印,這個好理解,但如果我這樣寫呢:

$sz = @arr;  #

把陣列賦值給乙個標量,perl 會把陣列的大小賦值給左邊的變數,所以上面的例子裡,$sz 等於2。如果perl沒法判斷,當前上下文是標量還是陣列,預設情況下,@arr 都會展開陣列:

@arr2 = (1,2,@arr);  # arr2 == (1,2,"abc","ed").

但如果這時候,我是想讓 @arr 當作標量來處理,怎麼辦?上面的寫法是不行的。perl 規定,如果想要指明轉換為標量型別,就需要加上關鍵字: scalar.

@arr2 = (1,2,scalar @arr);  # arr2 == (1,2,2)     

(4) sort 排序功能

perl 為陣列提供了排序操作符:sort。預設情況下,sort 對陣列裡的元素按字母排序,然後返回乙個新的陣列,舊陣列不變。

@arr = ("abc","rsz","ef");

@newarr = sort(@arr);

#  arr = abc rsz ef    newarr = abc ef rsz.

如果陣列裡存的不是字元,或你不想按字元序排序, 可以指定按數字的方式排序。

sort ( @array) 

大括號表示乙個比較函式,<=> 是指數值比較,$a 和 $b 表示比較的兩個數,這兩個變數是語言預定義的變數不可以更改。如果把a,b的順序調換一下,就表示反過來排序,如果用了數值排序,而陣列中又有字串元素,那字串都被當作 0,如果有多個字串,字串之間仍按字母序來排序。如:

@arr = (22,44,33,-12,gg ,hh)

sort(";  #列印出:value1.

上面的初始化語句在 key,value 很多時可讀性很差,因此,perl 又提供了另一種寫法:

%hash = ("key1"=>"value1","key2"=>"value2");

其中符號=> 與逗號的效果是完全一樣,但這種寫法看起來,就比較容易分辨別哪個是 key, 哪個是 value.

(2) 插入,刪除與修改

hash 的插入與修改在語法上是完全一樣的。

$hash = "value";

如果 hash 陣列中原來沒有 「key」,就插入;如果有"key"及相應"value",如果原來有相應的 "key",就修改相應的 value 為新的 「value"。與此同時,perl 提供了乙個 delete 操作符來刪除 hash 中的元素,如: delete $hash;

(3) 獲取 key 與 value.

perl 提供了keys 和 values 這兩個函式來獲取 hash 中的全部 key,value。這兩個操作符返回的是乙個陣列,如:

%hash = ("k1"=>"v1","k2"=>"v2");

@k = keys (%hash);    #k == ("k1","k2")

@v = values(%hash);   #v == ("v1","v2")

ref:

perl入門知識(2)

互動式程式設計 你可以在命令列中使用 e 選項來輸入語句來執行 例項如下 perl e print hello world n 輸入以上命令,回車後,輸出結果為 hello world 指令碼式程式設計 我們將以下 放到 hello.pl 檔案中 usr bin perl 輸出 hello,worl...

perl入門知識(3)

引用 在很多場合下使用引用傳值,能在很大程度上提高 的執行效率。定義乙個引用在變數名前加 就可以了,如 ra a rb b rc c 變數名前面依然是 而得到的引用是不能直接當做變數使用,需要解引用。解引用的方法是在變數名前加上變數原本型別所對應的符號。比如 rb是對乙個陣列的引用,那為了得到陣列,...

perl入門知識(3)

引用 在很多場合下使用引用傳值,能在很大程度上提高 的執行效率。定義乙個引用在變數名前加 就可以了,如 ra a rb b rc c 變數名前面依然是 而得到的引用是不能直接當做變數使用,需要解引用。解引用的方法是在變數名前加上變數原本型別所對應的符號。比如 rb是對乙個陣列的引用,那為了得到陣列,...