佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > Perl中常見符號(hào)與操作

Perl中常見符號(hào)與操作

熱門標(biāo)簽:硅谷的囚徒呼叫中心 Win7旗艦版 客戶服務(wù) 百度AI接口 企業(yè)做大做強(qiáng) 語(yǔ)音系統(tǒng) 呼叫中心市場(chǎng)需求 電話運(yùn)營(yíng)中心

注釋:

1.單行: #print
2.多行:=pod …. =cut

查詢perl相關(guān):

Perldoc perlvar($a,$$,$”...)
Perldoc perfunc(sort…)
Perldoc perl 查看perldoc文章列表
Perldoc –q 正則表達(dá)式
Perldoc –f 函數(shù)名
Perldoc module_name 查看模塊
Perldoc –v 變量名 查看變量
Perldoc perlop 查看操作符

查看模塊相關(guān)函數(shù):

1.Perl –d –e 0
2.Use module::submod
3.S module::submod

測(cè)試程序運(yùn)行時(shí)間:

1.Unix下:Time perl5 perl_program
2.程序內(nèi)添加:$end_time = time();$elapsed_time = $^T - $end_time; print $elapsed_time;
3.perl程序內(nèi)使用benchmark模塊: use benchmark; timestamp1 = new benchmark; {Code};timesamp2 = new benchmark; time_run = timediff(timestamp2 - timesamp1);

符號(hào):

=> Spaceship operator,太空船操作符:三向的比較數(shù)字操作符。$a=>$b 這個(gè)操作符比較兩個(gè)數(shù)字,返回-1,0,1。返回1:$a>$b,返回0:$a=$b,返回-1:$a$b。
$a,$b在sort中使用時(shí)代表第一個(gè)和第二個(gè)進(jìn)來的標(biāo)量或數(shù)組等
$! 根據(jù)上下文內(nèi)容返回錯(cuò)誤號(hào)或者錯(cuò)誤串
$” 列表分隔符
$# 打印數(shù)字時(shí)默認(rèn)的數(shù)字輸出格式
$$ Perl解釋器的進(jìn)程ID
$% 當(dāng)前輸出通道的當(dāng)前頁(yè)號(hào)
$ 與上個(gè)格式匹配的字符串
$( 當(dāng)前進(jìn)程的組ID$) 當(dāng)前進(jìn)程的有效組ID
$* 設(shè)置1表示處理多行格式.現(xiàn)在多以/s和/m修飾符取代之.
$, 當(dāng)前輸出字段分隔符
$. 上次閱讀的文件的當(dāng)前輸入行號(hào)
$/ 當(dāng)前輸入記錄分隔符,默認(rèn)情況是新行
$: 字符設(shè)置,此后的字符串將被分開,以填充連續(xù)的字段.
$; 在仿真多維數(shù)組時(shí)使用的分隔符.
$? 返回上一個(gè)外部命令的狀態(tài)
$@ Perl解釋器從eval語(yǔ)句返回的錯(cuò)誤消息
$[ 數(shù)組中第一個(gè)元素的索引號(hào)
$\ 當(dāng)前輸出記錄的分隔符
$] Perl解釋器的子版本號(hào)
$^ 當(dāng)前通道最上面的頁(yè)面輸出格式名字
$^A 打印前用于保存格式化數(shù)據(jù)的變量
$^D 調(diào)試標(biāo)志的值
$^E 在非UNIX環(huán)境中的操作系統(tǒng)擴(kuò)展錯(cuò)誤信息
$^F 最大的文件捆述符數(shù)值
$^H 由編譯器激活的語(yǔ)法檢查狀態(tài)
$^I 內(nèi)置控制編輯器的值
$^L 發(fā)送到輸出通道的走紙換頁(yè)符
$^M 備用內(nèi)存池的大小
$^O 操作系統(tǒng)名
$^P 指定當(dāng)前調(diào)試值的內(nèi)部變量
$^R 正則表達(dá)式塊的上次求值結(jié)果
$^S 當(dāng)前解釋器狀態(tài)
$^T 從新世紀(jì)開始算起,腳步本以秒計(jì)算的開始運(yùn)行的時(shí)間
$^V perl版本
$^W 警告開關(guān)的當(dāng)前值
$^X Perl二進(jìn)制可執(zhí)行代碼的名字 (perl指令)
$_ 默認(rèn)的輸入/輸出和格式匹配空間
$| 控制對(duì)當(dāng)前選擇的輸出文件句柄的緩沖
$~ 當(dāng)前報(bào)告格式的名字
$` 在上個(gè)格式匹配信息前的字符串
$' 在上個(gè)格式匹配信息后的字符串
$+ 與上個(gè)正則表達(dá)式搜索格式匹配的最后一個(gè)括號(hào)
$ 當(dāng)前執(zhí)行解釋器的用戶的真實(shí)ID
$ 含有與上個(gè)匹配正則表達(dá)式對(duì)應(yīng)括號(hào)結(jié)果
$= 當(dāng)前頁(yè)面可打印行的數(shù)目
$> 當(dāng)前進(jìn)程的有效用戶ID包含正在執(zhí)行的腳本的文件名
$ARGV 從默認(rèn)的文件句柄中讀取時(shí)的當(dāng)前文件名
%ENV 環(huán)境變量列表
%INC 通過do或require包含的文件列表
%SIG 信號(hào)列表及其處理方式
@_ 傳給子程序的參數(shù)列表
@ARGV 傳給腳本的命令行參數(shù)列表
@INC 在導(dǎo)入模塊時(shí)需要搜索的目錄列表
$-[0]和$+[0] 代表當(dāng)前匹配的正則表達(dá)式在被匹配的字符串中的起始和終止的位置

while(){ 
  my($date,$desc,$income,$expend) = unpack(“A10xA27xA7xA*”); 

簡(jiǎn)單說明:

  A10: A表示ASCII,A10表示10個(gè)ASCII character, Date的表示就是用10個(gè)ASCII碼;
  x  : x表示null byte也等于skip a byte,也就是說我們要跳過一個(gè)char(|),
  A27: 然后接著27個(gè)ASCII char,
  x  : 然后跳過一個(gè)vhar,
  A7 : 再接上7個(gè)ASCII,
  x  : 在跳過一個(gè)char,
  A* : 最后A*表示不管后面char有多少個(gè),全含括進(jìn)來。

在通常的子例程調(diào)用過程中,并不會(huì)搜索@ISA數(shù)組。但如果用戶以調(diào)用方法的語(yǔ)法來調(diào)用子程序的話,程序就會(huì)去搜索@ISA數(shù)組。

  @ISA     = qw(Exporter Net::Cmd IO::Socket::INET);
 
vars 是一個(gè)Perl的pragma,用來預(yù)定義全局變量。這些預(yù)定義后的全局變量qw()列表中的在整個(gè)Perl文件中皆可使用,使用了use strict也不會(huì)報(bào)警:
use vars qw($TELNET_IAC $TELNET_IP $TELNET_DM);
($TELNET_IAC,$TELNET_IP,$TELNET_DM) = (255,244,242);


$-[0]和$+[0] 代表當(dāng)前匹配的正則表達(dá)式在被匹配的字符串中的起始和終止的位置
|- 打開一個(gè)“輸出到”管道,那么你就可以向你打開的這個(gè)文件句柄寫數(shù)
-| 打開一個(gè)“來自”管道,那么你可以從這個(gè)文件句柄讀取數(shù)據(jù)


#!/usr/bin/perl
print $_.”\n”;#缺省輸入。
print @_.”\n”;#函數(shù)參數(shù)


#局域變量
print $.”\n”;#當(dāng)字符串用于模式匹配時(shí),字符串被分成了三部分:匹配以前的部分,匹配上的部分,匹配以后的部分。任何部分都可能是空,這個(gè)變量指最近一次匹配上的字符串。
print $'.”\n”;#匹配部分以后的部分。
print $`.”\n”;#最近一次匹配,匹配部分以前的部分。
print $+.”\n”;#最后一個(gè)圓括號(hào)中的子表達(dá)式匹配的部分。
print $*.”\n”;#缺省情況下,Perl 為了加快匹配速度,假設(shè)模式中不包括新行,也就是只執(zhí)行單行匹配。如果要執(zhí)行多行匹配,就要把此值設(shè)成 1。
print @+.”\n”;#這個(gè)數(shù)組保存當(dāng)前匹配的最后成功子匹配的結(jié)尾的偏移量。$+[0]是整個(gè)匹配的偏移量。$+[1]是$1 結(jié)束的偏移量,$+[2]是$2 結(jié)束的偏移量。
print @-.”\n”;#$-[0] 是最后一個(gè)成功的匹配的開始的偏移量。$-[n]是第 n 個(gè)子模式的偏移量,或 undef,如果沒有匹配上的話。$-[0]也可
以看成是整個(gè)匹配開始的偏移量。$-[1]是$1開始的地方,$-[2] 是$2 開始的地方,依次類推。
print
#輸入、輸出變量
print $..”\n”;#最近一次執(zhí)行讀操作的當(dāng)前行數(shù)。顯式的關(guān)閉文件句柄重置行數(shù)。
print $/.”\n”;#輸入記錄分隔符,缺省值是新行。
print $,.”\n”;#print操作的輸出域分隔符。
print $\..”\n”;#print 操作的輸出記錄分隔符。通常用于省略換行符。
print $”.”\n”;#當(dāng)數(shù)組轉(zhuǎn)換成字符串時(shí),元素缺省以空格分隔(例如,當(dāng)打印數(shù)組時(shí))。這個(gè)變量即代表這個(gè)分隔符,缺省是空格。
print $^L.”\n”;#當(dāng)執(zhí)行一個(gè)進(jìn)紙動(dòng)作時(shí)輸出的字符。缺省是 \f。
print $:.”\n”;#就是目前可以作為折行的字符集合。缺省值是” \n“(也就是空白,換行字符,以及連字號(hào))。
print $^A.”\n”;#格式化行的寫收集器的當(dāng)前值。


#錯(cuò)誤變量
print $?.”\n”;#$CHILD_ERROR 包含了最近一次執(zhí)行的外部程序結(jié)束狀態(tài)。這些程序以辦是通過管道,反小點(diǎn) (”) 或system 函數(shù)執(zhí)行的。
print $!.”\n”;#$OS_ERROR, $ERRNO 包含了系統(tǒng)的錯(cuò)誤。如果用在數(shù)值的地方,就是系統(tǒng)錯(cuò)誤碼;如果用在字符串的地方,就是錯(cuò)誤信息字符串。
print $^E.”\n”;#$EXTENDED_OS_ERROR 在某些平臺(tái),返回?cái)U(kuò)展錯(cuò)誤信息。
print $@.”\n”;#$EVAL_ERROR 從上一個(gè) eval 命令的 Perl 語(yǔ)法錯(cuò)誤信息


#系統(tǒng)變量
print $$.”\n”;#運(yùn)行當(dāng)前腳本的 Perl 進(jìn)程的 pid。
print $.”\n”;#當(dāng)前進(jìn)程的實(shí)際用戶標(biāo)識(shí)符(uid)。
print $>.”\n”;#當(dāng)前進(jìn)程的有效用戶標(biāo)識(shí)符。
print $(.”\n”;#當(dāng)前進(jìn)程的實(shí)際組標(biāo)識(shí)符(gid)。
print $).”\n”;#當(dāng)前進(jìn)程的有效組標(biāo)識(shí)符。
print $0.”\n”;#正在執(zhí)行的 Perl 腳本的文件名稱。這個(gè)參數(shù)與執(zhí)行時(shí)輸入有關(guān)
print $[."\n";#數(shù)組中第一個(gè)元素的序號(hào)或子串中第一個(gè)字符的序號(hào)。缺省是 0。
print $].”\n”;#返回版本號(hào),加上補(bǔ)丁級(jí)別除以 1000。
print $M.”\n”;#$M 的內(nèi)容能用作緊急內(nèi)存池,以便 Perl 出out-of-memory 錯(cuò)誤時(shí)使用。使用$M 要求 Perl 進(jìn)行特殊的編譯。
print $^F.”\n”;#最大的系統(tǒng)文件描述符,通常是 2。
print $^I.”\n”;#原地編輯擴(kuò)展的當(dāng)前值??墒褂?undef 禁止原地編輯。
print $^W.”\n”;#警告開關(guān)的當(dāng)前值,真或假。
print $^T.”\n”;#當(dāng)前腳本開始運(yùn)行的時(shí)間。以秒為單位,從 1970年開始。
print $^O.”\n”;#編譯 Perl 本身時(shí)的操作系統(tǒng)名稱。
print $^X.”\n”;#二進(jìn)制 Perl 執(zhí)行文件的名稱。
print $^D.”\n”;#調(diào)試標(biāo)志的當(dāng)前值。
print $^P.”\n”;#是否打開調(diào)試。
print $ARGV.”\n”;#當(dāng)從 >讀入時(shí)的當(dāng)前文件名。


#其它
print @ARGV.”\n”;#命令行參數(shù)。
print $ARGV.”\n”;#當(dāng)前文件的文件名,代表標(biāo)準(zhǔn)輸入STDIN>。
print @INC.”\n”;#尋找 Perl 腳本的地址表。
print %INC;#通過 do 或 requir 包含的文件名的目錄。
print $#ARGV 數(shù)組長(zhǎng)度-1

您可能感興趣的文章:
  • Perl5和Perl6對(duì)比使用Sigils的差別
  • Perl6中的垃圾收集
  • 強(qiáng)大的Perl正則表達(dá)式實(shí)例詳解
  • Perl中的符號(hào) ->;、=>; 和 :: 分別表示什么意思?
  • Perl學(xué)習(xí)教程之單行命令詳解
  • Perl時(shí)間處理函數(shù)用法介紹
  • Perl字符串處理函數(shù)大全
  • 詳解linux下批量替換文件內(nèi)容的三種方法(perl,sed,shell)
  • Perl與JS的對(duì)比分析(數(shù)組、哈希)
  • 使用Perl生成隨機(jī)密碼
  • ASP.NET中HyperLink超鏈接控件的使用方法
  • 將Perl5代碼遷移到Perl6上的解決方案

標(biāo)簽:海南 山西 長(zhǎng)沙 山西 喀什 崇左 濟(jì)南 安康

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Perl中常見符號(hào)與操作》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    澄江县| 梧州市| 务川| 吴桥县| 玉山县| 固始县| 侯马市| 庆城县| 黄石市| 叙永县| 巩留县| 商河县| 宜都市| 绿春县| 平泉县| 高碑店市| 丹寨县| 赫章县| 于田县| 门源| 滦南县| 弥渡县| 思茅市| 寿宁县| 井研县| 临湘市| 浙江省| 和田县| 湾仔区| 广昌县| 青冈县| 佛坪县| 龙海市| 思南县| 霍林郭勒市| 宣化县| 渝中区| 斗六市| 山西省| 报价| 加查县|