首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在列表中使用python中的正则表达式匹配数字

如何在列表中使用python中的正则表达式匹配数字
EN

Stack Overflow用户
提问于 2013-05-11 03:40:09
回答 2查看 172关注 0票数 0

我有srt格式的字幕,我有功能

代码语言:javascript
复制
def clearSubtitles(subtitles):
        for i in subtitles:
             if re.search("^\r$", i) != None :
                  subtitles.remove(i)
             if  re.search("^\d+\r$", i) != None:
                   subtitles.remove(i)  

在列表中,我有subtitles['0\r','00:59:58,084 --> 00:59:58,888\r','Come on!\r']

我需要匹配大小写0\r中的第一个短语,但是^\d+\r$匹配me timewindows(00:59:58,084 --> 00:59:58,888\r) ..有人能帮帮我吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-05-11 04:19:58

好了,我想我现在明白你想要删除什么了。试试这个:

代码语言:javascript
复制
import re

cleared_subtitles = [subtitle for subtitle in subtitles if not re.match(r'\d*\r')]

这将生成一个新列表,其中包含所有以0或更多数字开头、\r以删除结尾的元素。与re.search不同,re.match要求regexp匹配整个字符串。

票数 1
EN

Stack Overflow用户

发布于 2013-05-11 03:42:41

所以你需要用一个数字来匹配行?

代码语言:javascript
复制
re.search(r"^\d\r", i)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16489689

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档