⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 perl6.htm

📁 perl快速入门。由浅入深
💻 HTM
📖 第 1 页 / 共 2 页
字号:
<html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb_2312-80">
<title>Perl中文手册</title>
<LINK rel="stylesheet" href="mystyle.css" type="text/css">
</head>
<body>


<table border="0" width="100%" height="400" cellspacing="0" cellpadding="0">
  <tr>
    <td width="20%" valign="top" bgcolor="#dddddd">
     <table border="0" width="100%" cellpadding="0">
	<tr>
	  <td width="5%">
	  </td>
	  <td width="95%">
<p align="center">Perl 5教程<br>
<a target="_blank" href="http://flamephoenix.126.com">by flamephoenix</a></p>
<p align="center">目录</p>
<p align="center">第一部分  Perl语言</p>
<p><a href="perl1.htm">第一章 概述</a></p>
<p><a href="perl2.htm">第二章 简单变量</a></p>
<p><a href="perl3.htm">第三章 操作符</a></p>
<p><a href="perl4.htm">第四章 列表和数组变量 </a></p>
<p><a href="perl5.htm">第五章 文件读写 </a></p>
<p><a href="perl6.htm">第六章 模式匹配</a></p>
<p><a href="perl7.htm">第七章 控制结构</a></p>
<p><a href="perl8.htm">第八章 子程序</a></p>
<p><a href="perl9.htm">第九章 关联数组(哈希表)</a></p>
<p><a href="perl10.htm">第十章 格式化输出</a></p>
<p><a href="perl11.htm">第十一章 文件系统</a></p>
<p><a href="perl12.htm">第十二章 引用(指针)</a></p>
<p><a href="perl13.htm">第十三章 面向对象编程</a></p>
<p><a href="perl14.htm">第十四章 包和模块</a></p>
<p><a href="func.htm">附录一 函数集</a></p>
<p align="center">第二部分 Perl的CGI应用</p>
<p><a href="cgi1.htm">第一章 cgilib例</a></p>
<p><a href="cgi2.htm">第二章 动态创建图像</a></p>
<p><a href="cgi3.htm">第三章 计数器的编写方法</a></p>
<p><a href="cgi4.htm">第四章 Web Server设置</a></p>
第五章、...<br>
	  </td>
	</tr>
      </table>
    </td>
    <td width="80%" valign="top">
     <table border="0" width="100%" cellpadding="0">
	<tr>
	  <td width="1%">
	  </td>
	  <td width="99%">
<p align="center">第六章 模式匹配<br></p>

<p align="center"><a target="_blank" href="http://flamephoenix.126.com">by flamephoenix</a></p>

<a href="#一、简介">一、简介</a><br>
<a href="#二、匹配操作符">二、匹配操作符</a><br>
<a href="#三、模式中的特殊字符">三、模式中的特殊字符</a><br>
&nbsp;&nbsp;<a href="#1、字符 +">1、字符+</a><br>
&nbsp;&nbsp;<a href="#2、字符 []和[^]">2、字符 []和[^]</a><br>
&nbsp;&nbsp;<a href="#3、字符 *和?">3、字符 *和?</a><br>
&nbsp;&nbsp;<a href="#4、转义字符">4、转义字符</a><br>
&nbsp;&nbsp;<a href="#5、匹配任意字母或数字">5、匹配任意字母或数字</a><br>
&nbsp;&nbsp;<a href="#6、锚模式">6、锚模式</a><br>
&nbsp;&nbsp;<a href="#7、模式中的变量替换">7、模式中的变量替换</a><br>
&nbsp;&nbsp;<a href="#8、字符范围转义前缀">8、字符范围转义前缀</a><br>
&nbsp;&nbsp;<a href="#9、匹配任意字符">9、匹配任意字符</a><br>
&nbsp;&nbsp;<a href="#10、匹配指定数目的字符">10、匹配指定数目的字符</a><br>
&nbsp;&nbsp;<a href="#11、指定选项">11、指定选项</a><br>
&nbsp;&nbsp;<a href="#12、模式的部分重用">12、模式的部分重用</a><br>
&nbsp;&nbsp;<a href="#13、转义和特定字符的执行次序">13、转义和特定字符的执行次序</a><br>
&nbsp;&nbsp;<a href="#14、指定模式定界符">14、指定模式定界符</a><br>
&nbsp;&nbsp;<a href="#15、模式次序变量">15、模式次序变量</a><br>
<a href="#四、模式匹配选项">四、模式匹配选项</a><br>
&nbsp;&nbsp;<a href="#1、匹配所有可能的模式(g选项)">1、匹配所有可能的模式(g选项)</a><br>
&nbsp;&nbsp;<a href="#2、忽略大小写(i选项)例">2、忽略大小写(i选项)例</a><br>
&nbsp;&nbsp;<a href="#3、将字符串看作多行(m选项)">3、将字符串看作多行(m选项)</a><br>
&nbsp;&nbsp;<a href="#4、只执行一次变量替换例">4、只执行一次变量替换例</a><br>
&nbsp;&nbsp;<a href="#5、将字符串看作单行例">5、将字符串看作单行例</a><br>
&nbsp;&nbsp;<a href="#6、在模式中忽略空格">6、在模式中忽略空格</a><br>
<a href="#五、替换操作符">五、替换操作符</a><br>
<a href="#六、翻译操作符">六、翻译操作符</a><br>
<a href="#七、扩展模式匹配">七、扩展模式匹配</a><br>
&nbsp;&nbsp;<a href="#1、不存贮括号内的匹配内容">1、不存贮括号内的匹配内容</a><br>
&nbsp;&nbsp;<a href="#2、内嵌模式选项">2、内嵌模式选项</a><br>
&nbsp;&nbsp;<a href="#3、肯定的和否定的预见匹配">3、肯定的和否定的预见匹配</a><br>
&nbsp;&nbsp;<a href="#4、模式注释">4、模式注释</a><br>

<br><br><a name="一、简介">一、简介<br></a>
&nbsp;&nbsp; 模式指在字符串中寻找的特定序列的字符,由反斜线包含:/def/即模式def。其用法如结合函数split将字符串用某模式分成多个单词:@array
= split(/ /, $line);<br>
<a name="二、匹配操作符">二、匹配操作符</a>
  =~、!~<br>
&nbsp;&nbsp; =~检验匹配是否成功:$result
= $var =~ /abc/;若在该字符串中找到了该模式,则返回非零值,即true,不匹配则返回0,即false。!~则相反。<br>
&nbsp;&nbsp; 这两个操作符适于条件控制中,如:<br>
&nbsp;&nbsp; if ($question =~
/please/) {<br>
&nbsp;&nbsp;&nbsp;&nbsp; print
(&quot;Thank you for being polite!\n&quot;);<br>
&nbsp;&nbsp; }<br>
&nbsp;&nbsp; else {<br>
&nbsp;&nbsp;&nbsp;&nbsp; print
(&quot;That was not very polite!\n&quot;);<br>
&nbsp;&nbsp; }
<br>
<a name="三、模式中的特殊字符">
三、模式中的特殊字符</a>
<br>
&nbsp;&nbsp; PERL在模式中支持一些特殊字符,可以起到一些特殊的作用。<br>
<a name="1、字符 +">1、字符 +</a>
<br>
&nbsp;&nbsp; +意味着一个或多个相同的字符,如:/de+f/指def、deef、deeeeef等。它尽量匹配尽可能多的相同字符,如/ab+/在字符串abbc中匹配的将是abb,而不是ab。<br>
&nbsp;&nbsp; 当一行中各单词间的空格多于一个时,可以如下分割:<br>
&nbsp;&nbsp;&nbsp;&nbsp; @array =
split (/ +/, $line);<br>
&nbsp;&nbsp; 注:split函数每次遇到分割模式,总是开始一个新单词,因此若$line以空格打头,则@array的第一个元素即为空元素。但其可以区分是否真有单词,如若$line中只有空格,则@array则为空数组。且上例中TAB字符被当作一个单词。注意修正。
<br>
<a name="2、字符 []和[^]">2、字符
[]和[^]</a><br>
&nbsp;&nbsp; []意味着匹配一组字符中的一个,如/a[0123456789]c/将匹配a加数字加c的字符串。与+联合使用例:/d[eE]+f/匹配def、dEf、deef、dEdf、dEEEeeeEef等。^表示除其之外的所有字符,如:/d[^deE]f/匹配d加非e字符加f的字符串。<br>
<a name="3、字符 *和?">3、字符
*和? </a><br>
&nbsp;&nbsp; 它们与+类似,区别在于*匹配0个、1个或多个相同字符,?匹配0个或1个该字符。如/de*f/匹配df、def、deeeef等;/de?f/匹配df或def。<br>
<a name="4、转义字符">4、转义字符</a>
<br>
&nbsp;&nbsp; 如果你想在模式中包含通常被看作特殊意义的字符,须在其前加斜线&quot;\&quot;。如:/\*+/中\*即表示字符*,而不是上面提到的一个或多个字符的含义。斜线的表示为/\\/。在PERL5中可用字符对\Q和\E来转义。<br>
<a name="5、匹配任意字母或数字">
5、匹配任意字母或数字</a>
<br>
&nbsp;&nbsp; 上面提到模式/a[0123456789]c/匹配字母a加任意数字加c的字符串,另一种表示方法为:/a[0-9]c/,类似的,[a-z]表示任意小写字母,[A-Z]表示任意大写字母。任意大小写字母、数字的表示方法为:/[0-9a-zA-Z]/。<br>
<a name="6、锚模式">6、锚模式</a>
<br>
</p>

<table border="1" width="50%">
    <tr>
        <td valign="top" width="115"> <b>锚</b></td>
        <td valign="top" width="264"> <b>描述</b></td>
    </tr>
    <tr>
        <td valign="top" width="115"> <tt>^</tt>
        或 <tt>\A</tt></td>
        <td valign="top" width="264"> 仅匹配串首
        </td>
    </tr>
    <tr>
        <td valign="top" width="115"> <tt>$</tt>
        或 <tt>\Z</tt></td>
        <td valign="top" width="264"> 仅匹配串尾</td>
    </tr>
    <tr>
        <td valign="top" width="115"> <tt>\b</tt></td>
        <td valign="top" width="264"> 匹配单词边界</td>
    </tr>
    <tr>
        <td valign="top" width="115"> <tt>\B</tt></td>
        <td valign="top" width="264"> 单词内部匹配</td>
    </tr>
</table>

<p>&nbsp;&nbsp; 例1:/^def/只匹配以def打头的字符串,/$def/只匹配以def结尾的字符串,结合起来的/^def$/只匹配字符串def(?)。\A和\Z在多行匹配时与^和$不同。<br>
&nbsp;&nbsp; 例2:检验变量名的类型:<br>
&nbsp;&nbsp;&nbsp;&nbsp; if ($varname
=~ /^\$[A-Za-z][_0-9a-zA-Z]*$/) {<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; print
(&quot;$varname is a legal scalar variable\n&quot;);<br>
&nbsp;&nbsp;&nbsp;&nbsp; } elsif
($varname =~ /^@[A-Za-z][_0-9a-zA-Z]*$/) {<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; print
(&quot;$varname is a legal array variable\n&quot;);<br>
&nbsp;&nbsp;&nbsp;&nbsp; } elsif
($varname =~ /^[A-Za-z][_0-9a-zA-Z]*$/) {<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; print
(&quot;$varname is a legal file variable\n&quot;);<br>
&nbsp;&nbsp;&nbsp;&nbsp; } else {<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; print
(&quot;I don't understand what $varname is.\n&quot;);<br>
&nbsp;&nbsp;&nbsp;&nbsp;}<br>
&nbsp;&nbsp; 例3:\b在单词边界匹配:/\bdef/匹配def和defghi等以def打头的单词,但不匹配abcdef。/def\b/匹配def和abcdef等以def结尾的单词,但不匹配defghi,/\bdef\b/只匹配字符串def。注意:/\bdef/可匹配$defghi,因为$并不被看作是单词的部分。<br>
&nbsp;&nbsp; 例4:\B在单词内部匹配:/\Bdef/匹配abcdef等,但不匹配def;/def\B/匹配defghi等;/\Bdef\B/匹配cdefg、abcdefghi等,但不匹配def,defghi,abcdef。<br>
<a name="7、模式中的变量替换">
7、模式中的变量替换</a>
<br>
&nbsp;&nbsp; 将句子分成单词:<br>
&nbsp;&nbsp;&nbsp;&nbsp; $pattern =
&quot;[\\t ]+&quot;;<br>
&nbsp;&nbsp;&nbsp;&nbsp; @words =
split(/$pattern/, $line);<br>
<a name="8、字符范围转义前缀">
8、字符范围转义</a>
<br>
</p>

<table border="1" width="80%">
    <tr>
        <td valign="top" width="135"><b>E</b>
        转义字符</td>
        <td valign="top" width="228"> 描述</td>
        <td valign="top" width="147"> 范围</td>
    </tr>
    <tr>
        <td valign="top" width="135"> <tt>\d</tt></td>
        <td valign="top" width="228"> 任意数字</td>
        <td valign="top" width="147"> <tt>[0-9]</tt></td>
    </tr>
    <tr>
        <td valign="top" width="135"> <tt>\D</tt></td>
        <td valign="top" width="228"> 除数字外的任意字符
        </td>
        <td valign="top" width="147"> <tt>[^0-9]</tt></td>
    </tr>
    <tr>
        <td valign="top" width="135"> <tt>\w</tt></td>
        <td valign="top" width="228"> 任意单词字符</td>
        <td valign="top" width="147"> <tt>[_0-9a-zA-Z]</tt></td>
    </tr>
    <tr>
        <td valign="top" width="135"> <tt>\W</tt></td>
        <td valign="top" width="228"> 任意非单词字符</td>
        <td valign="top" width="147"> <tt>[^_0-9a-zA-Z]</tt></td>
    </tr>
    <tr>
        <td valign="top" width="135"> <tt>\s</tt></td>
        <td valign="top" width="228"> 空白</td>
        <td valign="top" width="147"> [
        \r\t\n\f]</td>
    </tr>
    <tr>
        <td valign="top" width="135"> <tt>\S</tt></td>
        <td valign="top" width="228"> 非空白</td>
        <td valign="top" width="147"> <tt>[^
        \r\t\n\f]</tt></td>
    </tr>
</table>

<p>&nbsp;&nbsp; 例:/[\da-z]/匹配任意数字或小写字母。<br>
<a name="9、匹配任意字符">9、匹配任意字符</a>
<br>
&nbsp;&nbsp; 字符&quot;.&quot;匹配除换行外的所有字符,通常与*合用。<br>
<a name="10、匹配指定数目的字符">
10、匹配指定数目的字符</a>
<br>
&nbsp;&nbsp; 字符对{}指定所匹配字符的出现次数。如:/de{1,3}f/匹配def,deef和deeef;/de{3}f/匹配deeef;/de{3,}f/匹配不少于3个e在d和f之间;/de{0,3}f/匹配不多于3个e在d和f之间。<br>
<a name="11、指定选项">11、指定选项</a>
<br>
&nbsp;&nbsp; 字符&quot;|&quot;指定两个或多个选择来匹配模式。如:/def|ghi/匹配def或ghi。<br>
&nbsp;&nbsp; 例:检验数字表示合法性<br>
&nbsp;&nbsp; if ($number =~
/^-?\d+$|^-?0[xX][\da-fa-F]+$/) {<br>
&nbsp;&nbsp;&nbsp;&nbsp; print
(&quot;$number is a legal integer.\n&quot;);<br>
&nbsp;&nbsp; } else {<br>
&nbsp;&nbsp;&nbsp;&nbsp; print
(&quot;$number is not a legal integer.\n&quot;);<br>
&nbsp;&nbsp; }<br>
&nbsp;&nbsp; 其中 ^-?\d+$
匹配十进制数字,^-?0[xX][\da-fa-F]+$
匹配十六进制数字。<br>
<a name="12、模式的部分重用">12、模式的部分重用</a>
<br>
&nbsp;&nbsp; 当模式中匹配相同的部分出现多次时,可用括号括起来,用\n来多次引用,以简化表达式:<br>
/\d{2}([\W])\d{2}\1\d{2}/ 匹配:<br>
&nbsp;&nbsp;&nbsp;&nbsp; 12-05-92<br>
&nbsp;&nbsp;&nbsp;&nbsp; 26.11.87<br>
&nbsp;&nbsp;&nbsp;&nbsp; 07 04 92等<br>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -