返回顶部
首页 > 资讯 > 后端开发 > Python >Pattern.compile函数提取字符串中指定的字符(推荐)
  • 225
分享到

Pattern.compile函数提取字符串中指定的字符(推荐)

Python 官方文档:入门教程 => 点击学习

摘要

  最近有个需求是要提取一段字符串中特定范围内的内容,查找资料后,使用的是Java中的Pattern.compile函数来实现对指定字符串的截取。记录下来查找的知

  最近有个需求是要提取一段字符串中特定范围内的内容,查找资料后,使用的是Java中的Pattern.compile函数来实现对指定字符串的截取。记录下来查找的知识和应用,方便以后的查看。

Pattern.compile函数语法

// Pattern.compile函数语法
Pattern Pattern.compile(String regex, int flag)

知识学习
Pattern.compile函数中两个参数
1、regex 表示定义的规则
2、flag 表示设置的参数类型,主要包含以下几种情况:
(1)Pattern.CASE_INSENSITIVE(?i) 默认情况下,大小写不明感的匹配只适用于US-ASCII字符集。让表达式忽略大小写进行匹配。
(2)Pattern.COMMENTS(?x) 此种模式下,匹配时会忽略表达式中空格字符(表达式里的空格,tab,回车)。注释从#开始,一直到这行结束。
(3)Pattern.UNIX_LINES(?d) 此种模式下,只有’\n’才被认作一行的中止,并且与’.’,’^’,以及’$’进行匹配。
(4)Pattern.MULTILINE(?m) 此种模式下,上箭头和单引号分别匹配一行的开始和结束。此外,’^‘仍然匹配字符串的开始,’’也匹配字符串的结束。默认情况下,这两个表达式仅仅匹配字符串的开始和结束。
(5)Pattern.DOTALL:此种模式下,表达式’.‘可以匹配任意字符,包括表示一行的结束符。默认情况下,表达式’.'不匹配行的结束符。

项目中程序例子

  在项目中运用的 flagCASE_INSENSITIVE参数,此处主要是截取中括号中的内容,截取的实现代码如下:

// 引入包
import java.util.regex.Matcher;
import java.util.regex.Pattern;

//需要截取的字符串
String splitStr = "[user:name] = select name from user";
// 定义规则
String pattern = "(\\[+)(\\w+)\\:(\\w+)(\\]+)";
//Pattern.compile函数
Matcher matcher = Pattern.compile(pattern, Pattern.CASE_INSENSITIVE).matcher(splitStr);
while (matcher.find()) { //表示往下遍历
	//截取出来的字符串 [user:name]
	String allcon = matcher.group(0);
	System.out.println("allcon匹配的结果为"+allcon);
	//截取的开始位置 [
	String tableJoin1 = matcher.group(1);
	System.out.println("tableJoin1匹配的结果为"+tableJoin1);
	//截取出来的表名 user
	String tableName = matcher.group(2);
	System.out.println("tableName匹配的结果为"+tableName);
	//截取出来的字段名 name
	String filed = matcher.group(3);
	System.out.println("filed匹配的结果为"+filed);
	//截取的结束位置 ]
	String tableJoin4 = matcher.group(4);
	System.out.println("tableJoin4匹配的结果为"+tableJoin4);
}

运行结果如下图所示。

在这里插入图片描述

  本程序中定义的规则表达式主要提取四个括号内的内容,以 \\ 符号为开始,后面跟截取的符号,w表示匹配的字符。按照此规则就可以提取出来相应的参数:tableName 表示提取的表名,filed 表示提取的字段名

参考下面教程

Pattern.compile函数的相关解释

Pattern.compile函数:Pattern Pattern.compile(String regex, int flag)

flag的取值范围如下:

Pattern.CANON_EQ:当且仅当两个字符的"正规分解(canonical decomposition)"都完全相同的情况下,才认定匹配。比如用了这个标志之后,表达 式"a\u030A"会匹配"?"。默认情况下,不考虑"规范相等性(canonical equivalence)"。

Pattern.CASE_INSENSITIVE: 默认情况下,大小写不敏感的匹配只适用于US-ASCII字符集。这个标志能让表达式忽略大小写进行匹配。要想对Unicode字符进行大小不明感的匹 配,只要将UNICODE_CASE与这个标志合起来就行了。

Pattern.COMMENTS: 在这种模式下,匹配时会忽略(正则表达式里的)空格字符(不是指表达式里的"\\s",而是指表达式里的空格,tab,回车之类)。注释从#开始,一直到这行结束。可以通过嵌入式的标志来启用Unix行模式。

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

Pattern.MULTILINE: 在这种模式下,'^'和'$'分别匹配一行的开始和结束。此外,'^'仍然匹配字符串的开始,'$'也匹配字符串的结束。默认情况下,这两个表达式仅仅匹配字符串的开始和结束。

Pattern.UNICODE_CASE: 在这个模式下,如果你还启用了CASE_INSENSITIVE标志,那么它会对Unicode字符进行大小写不明感的匹配。默认情况下,大小写不敏感的匹配只适用于US-ASCII字符集。

Pattern.UNIX_LINES(?d) 在这个模式下,只有'\n'才被认作一行的中止,并且与'.','^',以及'$'进行匹配。

到此这篇关于Pattern.compile函数提取字符串中指定的字符的文章就介绍到这了,更多相关Pattern.compile函数提取字符串指定字符内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Pattern.compile函数提取字符串中指定的字符(推荐)

本文链接: https://lsjlt.com/news/176121.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作