一堆re求化简

2012-12-24 00:03:20 +08:00
 ThunderEX
我有一串长长的:
for line in open('.txt'):

m = re.match(exp1, line, re.IGNORECASE)
if m:
func1(m.group())
continue

m = re.match(exp2, line, re.IGNORECASE)
if m:
func2(m.group())
continue

m = re.match(exp3, line, re.IGNORECASE)
if m:
func3(m.group())
continue

......
一来有一堆的正则解析和处理,二来别的别的地方还会调用其中几条,因而求教该怎么化简?
最初的想法是弄一个字典包含像exp1:func1, exp2:func2,然后一个for逐条解析,但是字典是无序的,因而不能按照上面的顺序一条一条跑。
然后觉得可以新建一个类,每个解析方法各弄一条子类,但是好像要写很多的样子……
总之想看看大神们怎么写的……
3260 次点击
所在节点    Python
4 条回复
reusFork
2012-12-24 00:11:36 +08:00
rules = [(exp1, func1), (exp2, func2), (exp3, func3)]
for l in lines: for exp, func in rules: if …………
wwwjfy
2012-12-24 00:21:12 +08:00
python有个东西叫OrderredDict
wwwjfy
2012-12-24 00:21:43 +08:00
写错了,OrderedDict
ThunderEX
2012-12-24 00:32:22 +08:00
@reusFork 唔…是我把问题想复杂了…好像新手都会把问题想复杂?为什么…

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/55655

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX