1、正則表達式特殊變量:
一、$n :包含上次模式匹配的第n個子串
二、$& :前一次成功模式匹配的字符串
三、$` :前次匹配成功的子串以前的內容
四、$’ :前次匹配成功的子串以後的內容
五、$+ :前一次使用括號的模式匹配的字符串. 正則表達式
2、文件句柄特殊變量:
一、$| :若是設置爲零,在每次調用函數write或print後,自動調用函數fflush,將所寫內容寫回文件
二、$% :當前輸出頁號
三、$= :當前每頁長度
四、$- :當前頁剩餘的行數
五、$~ :當前報表輸出格式的名稱.默認值是文件句柄名.
六、$^ :當前報表輸出表頭格式的名稱.默認值是帶後綴」_TOP」的文件句柄名. 數組
3、全局特殊變量:
一、$_和$ARG :默認輸入和模式匹配內容.若是不指定接收輸入的變量或執行模式匹配的字符串
二、$.和$NR :前一次讀的文件句柄的當前行號
三、$/和$RS :輸入記錄分隔符,默認是新行字符.如用undef這個變量,將讀到文件結尾
四、$,的$OFS :輸出域分隔符.
五、$\和$ORS :輸出記錄分隔符
六、$: :斷行字符,默認是」\n-」三個字符
七、$! :這個變量的數字值是errno的值,字符串值是對應的系統錯誤字符串
八、$@ :命令eval的錯誤消息.若是爲空,則表示上一次eval命令執行成功
九、$$ :運行當前Perl腳本程序的進程號
十、$< :當前進程的實際用戶號
十一、$> :當前進程的有效用戶號
十二、$( :當前進程的實際組用戶號
1三、$) :當前進程的有效組用戶號
1四、$[ :數組的數組第一個元素的下標,默認是0
1五、$] :Perl的版本號
1六、$ARGV :當使用」< >」讀文件時,保存當前文件名 編輯器
4、全局特殊數組變量:
一、@ARGV :保存命令行參數
二、@INC :保存查找Perl程序的目錄
三、@_ :在子程序內,這個數組變量包含傳遞給子程序的參數
四、%INC :散列表%INC包含全部用do或require語句包含的文件.關鍵字是文件名,值是這個文件的路徑
五、%ENV :包含當前環境變量
5、全局特殊文件句柄
一、ARGV :遍歷數組變量@ARGV中的全部文件名的特殊文件句柄
二、STDERR :標準錯誤輸出句柄
三、STDIN :標準輸入句柄
四、STDOUT :標準輸出句柄
PERL內置變量
$- 當前頁可打印的行數,屬於Perl格式系統的一部分
$! 根據上下文內容返回錯誤號或者錯誤串
$」 列表分隔符
$# 打印數字時默認的數字輸出格式
$$ Perl解釋器的進程ID
$% 當前輸出通道的當前頁號
$& 與上個格式匹配的字符串
$( 當前進程的組ID
$) 當前進程的有效組ID
$* 設置1表示處理多行格式.如今多以/s和/m修飾符取代之.
$, 當前輸出字段分隔符
$. 上次閱讀的文件的當前輸入行號
$/ 當前輸入記錄分隔符,默認狀況是新行
$: 字符設置,此後的字符串將被分開,以填充連續的字段.
$; 在仿真多維數組時使用的分隔符.
$? 返回上一個外部命令的狀態
$@ Perl解釋器從eval語句返回的錯誤消息
$[ 數組中第一個元素的索引號
$ 當前輸出記錄的分隔符
$] Perl解釋器的子版本號
$^ 當前通道最上面的頁面輸出格式名字
$^A 打印前用於保存格式化數據的變量
$^D 調試標誌的值
$^E 在非UNIX環境中的操做系統擴展錯誤信息
$^F 最大的文件捆述符數值
$^H 由編譯器激活的語法檢查狀態
$^I 內置控制編輯器的值
$^L 發送到輸出通道的走紙換頁符
$^M 備用內存池的大小
$^O 操做系統名
$^P 指定當前調試值的內部變量
$^R 正則表達式塊的上次求值結果
$^S 當前解釋器狀態
$^T 重新世紀開始算起,腳步本以秒計算的開始運行的時間
$^W 警告開關的當前值
$^X Perl二進制可執行代碼的名字
$_ 默認的輸入/輸出和格式匹配空間
$| 控制對當前選擇的輸出文件句柄的緩衝
$~ 當前報告格式的名字
$` 在上個格式匹配信息前的字符串
$’ 在上個格式匹配信息後的字符串
$+ 與上個正則表達式搜索格式匹配的最後一個括號
$< 當前執行解釋器的用戶的真實ID
$ 含有與上個匹配正則表達式對應括號結果
$= 當前頁面可打印行的數目
$> 當前進程的有效用戶ID
$0 包含正在執行的腳本的文件名
$ARGV 從默認的文件句柄中讀取時的當前文件名
%ENV 環境變量列表
%INC 經過do或require包含的文件列表
%SIG 信號列表及其處理方式
@_ 傳給子程序的參數列表
@ARGV 傳給腳本的命令行參數列表
@INC 在導入模塊時須要搜索的目錄列表
$-[0]和$+[0] 表明當前匹配的正則表達式在被匹配的字符串中的起始和終止的位置 。 函數