01 概 念
如果要处理的文件比较简单,直接使用字符串匹配就可以了,如下:
data:image/s3,"s3://crabby-images/4ed81/4ed8189de2ca96588f5d540645f4fec101db2c3b" alt="图片"
那么使用字符串匹配的python代码:
def find_start_re(fname):
f = open(fname,'r')
for line in f:
if line.startswith('re'):
print(line)
f.close()
find_start_re('re.txt')
执行结果:
data:image/s3,"s3://crabby-images/08fcd/08fcd04be8d931ad515d2cb424a7272b80352228" alt="图片"
单个处理数据和文本,效率不高,不适合数据量大的场景,正则表达式可以解决处理数据量大的情况。
正则表达式概念:
是对字符串操作的一种逻辑公式
应用场景:处理文本和数据
正则表达式过程:依次拿出表达式和文本中的字符比较,如果每一个字符都能匹配,则匹配成功,否则匹配失败
02 re 模块
re使用的过程:
data:image/s3,"s3://crabby-images/1b6bc/1b6bcb27da9b4926c4c743be8abf680935704996" alt="图片"
使用举例:
data:image/s3,"s3://crabby-images/37190/371904805157ffaa5d40fca83a59288bb7010bbf" alt="图片"
data:image/s3,"s3://crabby-images/fefcb/fefcbcc4ef798b9de89327a57987018f8f7976de" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/0b560/0b560a0256fa34db4adcb64d470e371957447349" alt="图片"
data:image/s3,"s3://crabby-images/8c690/8c690f69d454a7b235acc6a22f0a773c682c4227" alt="图片"
3.匹配时忽略大小写,增加re.I
data:image/s3,"s3://crabby-images/43db5/43db5c3a2e3e2bf3925ae38a2417eb34ddec3eee" alt="图片"
4.正则表达式语法
data:image/s3,"s3://crabby-images/1c540/1c540a69dd4b206e8f068bf401bb1b8d56864f0a" alt="图片"
data:image/s3,"s3://crabby-images/6007e/6007eebe8cbf744c4f49344e306494b4508aef35" alt="图片"
*的用法:
data:image/s3,"s3://crabby-images/f0dd1/f0dd1c0c939dbdb1e99234b8e00019d62322216b" alt="图片"
+的用法:匹配合理的变量名(必须以‘_’或者字母开头)
data:image/s3,"s3://crabby-images/66e62/66e62a47c10c65623bd5f59c128a01c5ce26ac8b" alt="图片"
?用法:匹配0-99的数字
data:image/s3,"s3://crabby-images/87aa2/87aa2f173f269d2038bebcdc456675097c376121" alt="图片"
{m}/{m,n}的用法:匹配合理的126邮箱(@126.com之前是6到10位字符)
data:image/s3,"s3://crabby-images/277e2/277e2cc49ab2890361f6910c029e6ffeac9438b5" alt="图片"
*?/+?/??的用法:
data:image/s3,"s3://crabby-images/25f54/25f54942cd9f0e1d50bbe857dcc4343134de265a" alt="图片"
5、正则表达式进行边界匹配
data:image/s3,"s3://crabby-images/8b88c/8b88ce87becc124d905c10a16d2beb3cb43e5b70" alt="图片"
6、正则表达式进行分组匹配
data:image/s3,"s3://crabby-images/0785b/0785bdea3a59f0314c3b04c1719db6901c19feb0" alt="图片"
| 的用法:匹配0-99的数字
data:image/s3,"s3://crabby-images/bea5a/bea5ac78b6d4d356b8e551f6b5a5ac6245a4ef77" alt="图片"
data:image/s3,"s3://crabby-images/a442a/a442acf713aaa8c325e4187a592bcf918ae845b8" alt="图片"
(ab)的用法:
data:image/s3,"s3://crabby-images/d74be/d74be717ef5b8868e3c64bb748b106e75bdbfbbd" alt="图片"
<number>的用法:处理xml文件时会经常用到 python
data:image/s3,"s3://crabby-images/3f5ae/3f5ae64c51a1a4e23fa4025ed9dade3a9befbcf1" alt="图片"
data:image/s3,"s3://crabby-images/4db4b/4db4b3d80b275a37216e231b5f7aca6c1e5d3c62" alt="图片"
(?P)、(?P=name)的用法:
data:image/s3,"s3://crabby-images/1f6e8/1f6e84abcdf291f2f66eb2188bfca7fab3c37b13" alt="图片"
03 re的其他方法
因为re模块的match方法是从头开始匹配的,当需要匹配字符串中的子串的时候就不好用了。
data:image/s3,"s3://crabby-images/c985c/c985c29cbd7834bfa5532684435b13dbedf4d80e" alt="图片图片" data:image/s3,"s3://crabby-images/1ed3e/1ed3e7c227577aaee48c995020cb058ea9dba833" alt="在这里插入图片描述"
search方法:
匹配字符串中的数字 ‘study python = 1000’
data:image/s3,"s3://crabby-images/a51fe/a51fe67d21b23899e7c6c2ecd6cb5c5ca3344aa1" alt="图片"
findall方法:
data:image/s3,"s3://crabby-images/8ac3e/8ac3e3500c43538d576dfb0940eb37d4bcee2905" alt="图片"
data:image/s3,"s3://crabby-images/9174f/9174f925562bd0321438f269dcb813e45d0dbc8b" alt="图片"
sub方法:
参数repl有两种方式,一种是本身就是字符串,一种是函数,取函数返回的字符串
data:image/s3,"s3://crabby-images/52b4d/52b4d1ea94939ee5bafcd0d6daf5cee17e4c3983" alt="图片"
split用法:
data:image/s3,"s3://crabby-images/faeaa/faeaa66a6397ea4c488230798bee8079aa248749" alt="图片"
现在我邀请你进入我们的软件测试学习交流群:【746506216 】,备注“入群”, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路。
资源分享
最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走…
data:image/s3,"s3://crabby-images/510a7/510a7b8afbae69531084d04d00624dd4648f4fb6" alt="在这里插入图片描述"
?这些资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。希望对大家有所帮助…….
data:image/s3,"s3://crabby-images/45b95/45b95e8344ba6b57e9680b676e52c019c005fd76" alt="在这里插入图片描述"
|