[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[问题求助] 求教一个Python正则表达式

match=re.compile("([idel])|(/d+):|(-?/d+)").match  

上面的是嵌套了吗?

match=re.compile("([idel])|(/d+):|(-?/d+)")

写成这样python解释器也是认可的。

回复 3# netdzb


   生成器唉……具体用法我也讲不清楚,反正就是返回一个可迭代对象就是了

TOP

回复 2# wujunkai

def tokenize(text, match=re.compile("([idel])|(/d+):|(-?/d+)").match):
        i = 0
        while i < len(text):
                m = match(text, i)
                s = m.group(m.lastindex)
                i = m.end()
                if m.lastindex == 2:
                        yield "s"
                        yield text[i:i+int(s)]
                        i = i + int(s)
                else:
                        yield s


src = tokenize(text)  

print(src)

====================

我完整的贴出来吧

函数定义成
def tokenize(text, match=re.compile("([idel])|(/d+):|(-?/d+)").match):

def tokenize(text, match=re.compile("([idel])|(/d+):|(-?/d+)")):
输出的src是一样的。
这里比较的难理解的点应该是yield。

这段代码究竟在干什么?

TOP

回复 1# netdzb


   那个。。。不知道你在哪里感到疑惑

TOP

返回列表