`
saybody
  • 浏览: 904381 次
  • 性别: Icon_minigender_2
  • 来自: 西安
文章分类
社区版块
存档分类
最新评论

Perl 正则表达式

阅读更多

正则表达式文中列表

\将下一个字符标记为一个特殊字符、或一个原义字符、或一个后向引用、或一个八进制转义符。

^匹配输入字符串的开始位置。如果设置了RegExp对象的Multiline属性,^也匹配’\n’或’\r’之后的位置。

$匹配输入字符串的结束位置。如果设置了RegExp对象的Multiline属性,$也匹配’\n’或’\r’之前的位置。

*匹配前面的子表达式零次或多次。

+匹配前面的子表达式一次或多次。+等价于{1,}。

?匹配前面的子表达式零次或一次。?等价于{0,1}。

{n}n是一个非负整数,匹配确定的n次。

{n,}n是一个非负整数,至少匹配n次。

{n,m}m和n均为非负整数,其中n<=m。最少匹配n次且最多匹配m次。在逗号和两个数之间不能有空格。

?当该字符紧跟在任何一个其他限制符(*,+,?,{n},{n,},{n,m})后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。

.匹配除"\n"之外的任何单个字符。要匹配包括’\n’在内的任何字符,请使用象’[.\n]’的模式.

(pattern)匹配pattern并获取这一匹配.

(?P<name>pattern)匹配pattern,匹配后goup可以用name代替数字m.group(1)->m.group('name').
(?:pattern)匹配pattern但不获取匹配结果,也就是说这是一个非获取匹配,不进行存储供以后使用。

(?=pattern)正向预查,在任何匹配pattern的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。

(?!pattern)负向预查,与(?=pattern)作用相反

x|y匹配x或y。

[xyz]字符集合。

[^xyz]负值字符集合。

[a-z]字符范围,匹配指定范围内的任意字符。

[^a-z]负值字符范围,匹配任何不在指定范围内的任意字符。

\b匹配一个单词边界,也就是指单词和空格间的位置。

\B匹配非单词边界。

\cx匹配由x指明的控制字符。

\d匹配一个数字字符。等价于[0-9]。

\D匹配一个非数字字符。等价于[^0-9]。

\f匹配一个换页符。等价于\x0c和\cL。

\n匹配一个换行符。等价于\x0a和\cJ。

\r匹配一个回车符。等价于\x0d和\cM。

\s匹配任何空白字符,包括空格、制表符、换页符等等。等价于[\f\n\r\t\v]。

\S匹配任何非空白字符。等价于[^\f\n\r\t\v]。

\t匹配一个制表符。等价于\x09和\cI。

\v匹配一个垂直制表符。等价于\x0b和\cK。

\w匹配包括下划线的任何单词字符。等价于’[A-Za-z0-9_]’。

\W匹配任何非单词字符。等价于’[^A-Za-z0-9_]’。

\xn匹配n,其中n为十六进制转义值。十六进制转义值必须为确定的两个数字长。

\num匹配num,其中num是一个正整数。对所获取的匹配的引用。

\n标识一个八进制转义值或一个后向引用。如果\n之前至少n个获取的子表达式,则n为后向引用。否则,如果n为八进制数字(0-7),则n为一个八进制转义值。

\nm标识一个八进制转义值或一个后向引用。如果\nm之前至少有 isprecededbyatleastnm个获取得子表达式,则nm为后向引用。如果\nm之前至少有n个获取,则n为一 个后跟文字m的后向引用。如果前面的条件都不满足,若n和m均为八进制数字(0-7),则\nm将匹配八进制转义值nm。

\nml如果n为八进制数字(0-3),且m和l均为八进制数字(0-7),则匹配八进制转义值nml。

\un匹配n,其中n是一个用四个十六进制数字表示的Unicode字符。
分享到:
评论

相关推荐

    Perl正则表达式讲解

    ### Perl正则表达式详解 #### 一、正则表达式的三大原则 正则表达式在Perl中的应用广泛,主要用于模式匹配、文本替换以及字符转换。掌握正则表达式的运用,能够极大地提升文本处理的效率和灵活性。以下是正则...

    Perl 正则表达式速查手册

    Perl正则表达式是用于文本处理的强大工具,被广泛应用于各种脚本编程任务中,包括数据验证、字符串替换、模式匹配等。本文档旨在为用户提供一个快速查阅Perl正则表达式的指南,包含了基本的特殊字符、元字符、锚点、...

    Perl正则表达式,常用函数和变量

    一、Perl正则表达式基础 Perl的正则表达式由一系列字符和元字符组成,它们共同构成一个模式,用于在字符串中查找匹配的模式。例如,`\d`代表数字,`.`代表任何字符,`*`表示前一个字符可以出现零次或多次。`^`表示...

    perl正则表达式详解

    Perl正则表达式是Perl语言中的强大工具,用于文本匹配、替换和转换。它们具有高度灵活性和表达能力,是处理字符串操作的核心部分。在Perl中,正则表达式主要有三种形式: 1. **匹配(Match)**:使用`m/&lt;regexp&gt;/`...

    perl 正则表达式

    ### Perl正则表达式详解 #### 一、Perl正则表达式概述 Perl(Practical Extraction and Reporting Language)是一种广泛应用于文本处理、Web 开发、系统管理等领域的脚本语言。其中,正则表达式是Perl中最强大的...

    perl正则表达式

    ### Perl正则表达式的深入解析 #### 原则概览 正则表达式是Perl语言中的一个强大工具,用于模式匹配、搜索和替换文本。根据提供的内容,我们可以看到正则表达式的应用遵循一系列的原则: 1. **原则1**:正则表达式...

    perl正则表达式的整理

    Perl正则表达式是Perl语言中的一个重要组成部分,用于文本匹配、搜索和替换操作。它们是强大的工具,能够处理复杂的字符串模式。以下是对Perl正则表达式的一些关键知识点的详细解释: 1. **基本匹配**: - `\d`:...

    Perl正则表达式

    ### Perl正则表达式详解 #### 一、概述 Perl是一种强大的脚本语言,尤其以其在文本处理方面的强大功能而闻名。正则表达式(Regular Expression)是Perl中用于匹配字符串的强大工具,它允许用户使用一种简洁的方式...

    perl正则表达式讲解

    ### Perl正则表达式详解 #### 一、Perl正则表达式基础介绍 在计算机科学领域,正则表达式是一种强大的文本处理工具,被广泛应用于字符串搜索与替换等操作之中。Perl作为一门脚本语言,其对正则表达式的支持尤为...

    grep、sed、awk、perl等对正则表达式的支持的差别

    在IT领域,文本处理是日常工作中不可或缺的一部分,而grep、sed、awk和perl这四个工具在处理文本时都广泛地使用了正则表达式。它们各自有着不同的特性和适用场景,理解它们之间的差异有助于我们更高效地进行文本操作...

    PCRE 【Perl兼容正则表达式解析库】

    Perl兼容正则表达式解析库,本资源包是作者制作的静态库,版本为7.8。使用VC6在WinXp下编译通过。使用时请将pcre.h放到VC的include目录下。

    Perl正则表达式讲解.chm

    Perl正则表达式讲解,真的非常详细,看了这个不用在费心去看别的Perl的关于正则表达式的内容的

    DEELX 是一个在 C++ 环境下的与 Perl 兼容的正则表达式引擎

    DEELX 将这种功能移植到了C++环境中,使得开发者无需离开他们熟悉的编程语言就能利用Perl正则表达式的强大之处。这包括但不限于以下关键特性: 1. **元字符**:DEELX 支持各种元字符,如 `.` (匹配任何非换行符的...

    C语言正则表达式库

    这个库名为PCRE(Perl Compatible Regular Expressions),正如其名,它与Perl语言中的正则表达式语法高度兼容,提供了丰富的功能和强大的匹配能力。PCRE2-10.31是该库的一个具体版本,包含了一系列头文件和库文件,...

Global site tag (gtag.js) - Google Analytics