下面说说如何使用python的正则表达式来匹配txt文本中的字符。
首先你要知道你要匹配的字符串的形式,然后根据你自己的字符串形式写出对应的正则表达式
比如这次我需要匹配的是数字加逗号加数字的字符串形式
所以我的正则表达式的形式如下
rule_name = r'\b(\d*,+\d+)\s'
compile_name = re.compile(rule_name, re.M)
\d代表一个数组,如果后面有符号,符号要加在*后面,\s是空格或者tab,\b代表break,不清楚是什么。 . r代表
原始字符串的意思,然后()就是最终的字符串。在这里,我的字符串不需要那些空格或中断,所以我在那些 \d
如果想用其他的代表形式,可以直接去百度找字母等表达方式。
那么接下来会用到compile。其中的re.M表示多行匹配。具体意思我不是很清楚。不知道是当文本多行的时候用的,还是匹配的。
多行字符的时候用,但是我这样写的时候没有出错,所以就继续这样写。
然后就是打开txt文件,这个很简单
#"获取文本"
f = open(path)
st = f.read()
path就是文本的路径了
然后直接调用findall函数,可以直接在这段文本中找到所有符合表达式的字符串,并返回一个列表,里面包含了所有找到的字符串
res_name = compile_name.findall(st)
这个res_name是一个列表,里面包含了所有找到的字符串
调用时直接res_name[i]可以找到对应的第i个字符串
推荐学习《
》。
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python中的随机模块对列表的内容进行洗牌11/17
- ♥ python3格式输出有哪些方法?12/30
- ♥ 如何在python中实现日期加减08/12
- ♥ python类有自己的方法吗?01/04
- ♥ python strftime和strptime的不同分析09/29
- ♥ 如何查看python中函数的使用情况08/18
内容反馈