正则表达式

当前位置:正则表达式 > jmeter

jmeter正则表达式.+?和.*?有啥区别

. 匹配除“\r\n”之外的任何单个字符。要匹配包括“\r\n”在内的任何字符,请使用像“[\s\S]”的模式。

匹配前面的子表达式0到1次
* 匹配前面的子表达式人任意次
+ 匹配前面的子表达式一次或多次>=1)
   
匹配前面的子表达式0到1次

加问号则表示为懒惰模式

  • .+? 表示匹配任意字符一个或则多个
  • .*? 表示匹配任意字符0个或多个

在具体使用时.+?可能跟好用些,看个人喜好

既然写了,顺带将正则的知识补全吧;;

在这里插入图片描述

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
"\b" :不会消耗任何字符只匹配一个位置,常用于匹配单词边界 如 我想从字符串中"This is Regex"匹配单独的单词 "is" 正则就要写成 "\bis\b" 
 
   \b 不会匹配is 两边的字符,但它会识别is 两边是否为单词的边界
 
"\d": 匹配数字,
 
"\w":匹配字母,数字,下划线.
 
"\s":匹配空格
 
 
 ".":匹配除了换行符(\r\n)以外的任何字符
 
   这个算是"\w"的加强版了"\w"不能匹配 空格 如果把字符串加上空格用"\w"就受限了,
   用 "."是如何匹配字符"a23 4 5 B C D__TTz"  正则:".+"
 
"[abc]": 字符组  匹配包含括号内元素的字符

匹配能力 ( . > \w > \d )

反义:
写法很简单改成大写就行了,这也很好理解;

1
2
3
4
5
6
7
8
9
10
   "\W"   匹配任意不是字母,数字,下划线 的字符
 
   "\S"   匹配任意不是空白符的字符
 
 "\D"  匹配任意非数字的字符
 
   "\B"  匹配不是单词开头或结束的位置
 
   "[^abc]"  匹配除了abc以外的任意字符
"{n}"  重复n次

例如从"aaaaaaaa" 匹配字符串的a 并重复3次 正则: “a{3}” 结果就是取到3个a字符 “aaa”;

“{n,m}” 重复n到m次

例如正则 “a{3,4}” 将a重复匹配3次或者4次 所以供匹配的字符可以是三个"aaa"也可以是四个"aaaa" 正则都可以匹配到

1 "{n,}" 重复n次或更多次

与{n,m}不同之处就在于匹配的次数将没有上限,但至少要重复n次 如 正则"a{3,}" a至少要重复3次

1 "??"  重复0次或1次,但尽可能少重复

如 “aaacb” 正则 “a.??b” 只会取到最后的三个字符"acb"

“{n,m}?” 重复n到m次,但尽可能少重复

1 如 "aaaaaa" 正则 "a{0,m}" 因为最少是0次所以取到结果为空

“{n,}?” 重复n次以上,但尽可能少重复

1 如 "aaaaa" 正则 "a{1,}" 最少是1次所以取到结果为 "a"
n+ 匹配n至少一次(>=1)
n? 匹配n 0次 或一次 (有与无)
n* 匹配n 随意次(*可代表任意字母)
   
?=n 匹配任何其后紧接指定字符串 n 的字符串
?!n 匹配任何其后没有紧接指定字符串 n 的字符串。

==>两者相互等价

n? n{0,1}
n+ n{1,}
n* n{0,}

 


相关文章
苏ICP备2022026517号-2  |   苏公网安备 32081202000316号
淮安先皓网络科技有限公司 © 版权所有  联系我们