`
njmnjx
  • 浏览: 234753 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

java 正则表达式 pattern.unix_lines(即?d)解释

阅读更多
在使用Pattern.compile函数时,可以加入控制正则表达式的匹配行为的参数: 
Pattern Pattern.compile(String regex, int flag) 

flag的取值范围如下: 
Pattern.CANON_EQ
当且仅当两个字符的"正规分解(canonical decomposition)"都完全相同的情况下,才认定匹配。比如用了这个标志之后,表达式"a\u030A"会匹配"?"。默认情况下,不考虑"规范相等性(canonical equivalence)"。
 
Pattern.CASE_INSENSITIVE(?i)
默认情况下,大小写不明感的匹配只适用于US-ASCII字符集。这个标志能让表达式忽略大小写进行匹配。要想对Unicode字符进行大小不明感的匹配,只要将UNICODE_CASE与这个标志合起来就行了。
 
Pattern.COMMENTS(?x)
在这种模式下,匹配时会忽略(正则表达式里的)空格字符(译者注:不是指表达式里的"\\s",而是指表达式里的空格,tab,回车之类)。注释从#开始,一直到这行结束。可以通过嵌入式的标志来启用Unix行模式。 

Pattern.DOTALL(?s) 
在这种模式下,表达式'.'可以匹配任意字符,包括表示一行的结束符。默认情况下,表达式'.'不匹配行的结束符。 

Pattern.MULTILINE (?m)
在这种模式下,'^'和'$'分别匹配一行的开始和结束。此外,'^'仍然匹配字符串的开始,'$'也匹配字符串的结束。默认情况下,这两个表达式仅仅匹配字符串的开始和结束。
 
Pattern.UNICODE_CASE (?u)
在这个模式下,如果你还启用了CASE_INSENSITIVE标志,那么它会对Unicode字符进行大小写不明感的匹配。默认情况下,大小写不敏感的匹配只适用于US-ASCII字符集。
 
Pattern.UNIX_LINES(?d)
在这个模式下,只有'\n'才被认作一行的中止,并且与'.','^',以及'$'进行匹配


以上内容中提到的Pattern.UNIX_LINES(?d)完整的相关解释如下:
      默认情况下(没有使用UNIX——LINES时)是识别完整的行终结符,匹配文本行边界的元字符会把CR/LF视为不可分隔的单位,一次性匹配这两个字符。

      举例来说,$和\Z通常会匹配行终结符之前的位置。LF是行终结符,但只有在它不属于CR/LF(也就是说,LF之前没有CR)的情况下,$和\Z才能匹配字符串末尾的LF之前的位置。

      MUTILINE模式中的$和^也是如此,在这种模式下,只有在CR之后没有LF的情况下,^才能匹配CR之后的位置;只有在LF之前不是CR的情况下,$才能匹配LF之前的位置。

      必须说清楚的是,DOTALL对CR/LF的处理没有影响(DOTALL只影响点号,而点号总是逐个处理字符的),UNIX——LINES根本不存在此类问题(它只识别CR,所有其它行终结符都不需要特殊处理)。

 
注:


  • 大小: 4.3 KB
分享到:
评论

相关推荐

    java正则表达式.pdf

    Java的正则表达式主要由`java.util.regex`包中的三个关键类构成:`Pattern`、`Matcher`和`PatternSyntaxException`异常类。 1. **Pattern类**:该类用于编译正则表达式字符串,并创建一个Pattern对象,用于匹配文本...

    Java正则表达式1

    在Java中,正则表达式是通过java.util.regex包中的Pattern和Matcher类来实现的。Pattern类用于编译正则表达式,而Matcher类用于执行正则表达式的匹配操作。 Pattern类 Pattern类是java.util.regex包中的一个final...

    Java正则表达式 介绍java正则表达式的基本语法

    ### Java正则表达式的介绍与基本语法 在Java编程中,正则表达式是一种非常强大的文本处理工具,它能够帮助开发者高效地进行字符串的搜索、替换等操作。自JDK 1.4版本以来,Java引入了`java.util.regex`包来支持正则...

    JAVA正则表达式详解

    Java正则表达式是通过`java.util.regex`包来支持的,该包主要包含三个核心类:`Pattern`、`Matcher`和`PatternSyntaxException`。其中,`Pattern`类用于编译正则表达式模式;`Matcher`类用于执行匹配操作;`...

    【高清PDF】正则表达式速查表,吐血推荐,绝对实用!!

    正则表达式在 Java 中的使用包括使用 Pattern 和 Matcher 类。Pattern 类用于编译正则表达式,Matcher 类用于执行匹配操作。与之相关的方法有: - `***pile(String regex)` 编译给定的正则表达式为一个模式。 - `**...

    一个java正则表达式工具类源代码.zip(内含Regexp.java文件)

    * Summary of regular-expression constructs 正则表达式结构简介: * Construct Matches * Characters 字符: * x The character x x 字符 x * \\ The ...

    正则表达式参考

    - `Pattern.UNIX_LINES`:仅识别 `\n` 为行终止符。 #### 四、示例代码解析 以下是一些简单的示例来说明如何在Java中使用正则表达式: 1. **匹配开头与结尾的字符串** ```java Pattern pattern = Pattern....

    正则表达式综合

    - `Pattern.UNIX_LINES` 表示只接受 Unix 格式的换行符。 4. **Java 实例** - **匹配**:使用 `Pattern.compile` 方法创建正则表达式模式对象,并通过 `matcher` 方法检查字符串是否符合该模式。 ```java ...

    学习记录_中级软件工程师软件工程师_网页设计

    根据提供的文件信息,我们可以归纳出以下关键知识点,主要聚焦于Java中的正则表达式应用、环境变量配置以及批处理文件的基础使用。 ### 正则表达式(Regular Expression) #### Pattern 类 - `Pattern` 类是正则...

    txt 删空行

    2. **Sublime Text**: 同样是流行的文本编辑器,使用方法类似Notepad++,通过`查找`->`替换`,在正则表达式模式下,查找`\n`并替换为空。 **方法二:使用命令行工具** 1. **Unix/Linux shell命令**: 在Linux或Mac...

Global site tag (gtag.js) - Google Analytics