正则表达式常用方法

前言:作为测试工程师,在工作中经常需要处理字符串,比如自动化测试过程中,在参数关联的时候就需要去响应结果中提取一些全局参数。如果参数是规则的json数据,我们可以使用jsonpath提取,如果参数为不规则的字符串,这个时候正则表达式便是最好的选择。一提到正则很多同学第一反应是很复杂,实际上正则功能很强大,但是对于我们测试测试工程师而言,我们只需要掌握一些常见的用法即可。下面我么就来看一下正则表达式有哪些常用的方法。

一、正则表达式作用

  • 匹配指定规则的字符串

二、常用方法

  • findall():RE匹配的所有子串,并把它们作为一个列表返回
    findall():RE匹配的所有子串,并把它们作为一个列表返回
    
    res=re.findall('www','www.baidu.www.com')
    print(res)
    输出:['www', 'www']
    
  • match():RE是否在字符创开始的位置匹配(只匹配开始位置),如果不是起始位置匹配成功的话,match()就返回none
    匹配起始位置为www,非其实位置返回None,group()返回re匹配的字符串
    res = re.match('www','www.baidu.com').group()
    print(res)
    输出:www
    
  • search():RE扫描整个字符串并返回第一个成功的匹配
    在'www.baidu.com'中匹配'www',返回匹配到的第一个
    result = re.search('www','www.baidu.com').group()
    print(result)
    输出:www
    
  • finditer():RE匹配的所有子串,并把它们作为一个迭代器返回
    finditer():匹配所有找到的子串,返回一个可迭代对象
    res = re.finditer('www','www.baidu.www.com')
    print(res)
    for i in res:
    print(i.group())
    输出:
    
    www
    www
    
  • 结果处理函数
    • group():返回RE匹配的字符串
    • span():返回匹配到字符串开始索引位置和结束索引位置的元组(开始,结束)
    • start():返回匹配到字符串的开始索引位置
    • end():返回匹配到字符串的结束索引位置
  • sub():替换字符串,返回替换后的字符串
    sub():替换字符串,返回替换后的字符串
    res3=re.sub('\d+','我把数字替换了','www.5555.com')
    print(res3)
    输出:www.我把数字替换了.com
    
  • subn():替换字符串,返回替换后的字符串,和替换次数
    subn():替换字符串&

你可能感兴趣的:(python,python)