正则表达式:如何在一个长字符串中找到一个GUID?

22 浏览
0 Comments

正则表达式:如何在一个长字符串中找到一个GUID?

假设我有这个字符串:\n

str = 'something-rows-1973912739821738172-25892e17-80f6-415f-9c65-7395632f0223'

\n我需要删除GUID部分:\n

\n25892e17-80f6-415f-9c65-7395632f0223\n

\n这是我目前的代码,但它不起作用:\n

c = re.compile('[0-9a-f]{12}4[0-9a-f]{3}[89ab][0-9a-f]{15}\Z', re.I)
res = c.match(str)
print(res)

\n请问有人可以帮忙吗?

0
0 Comments

问题的出现原因是想要在一个长字符串中找到GUID(全局唯一标识符)。为了解决这个问题,可以使用正则表达式来匹配GUID的模式。

具体的解决方法如下:

[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}

这个正则表达式可以用来匹配GUID的模式。你可以在这个链接上找到一个可以工作的示例。

需要注意的是,这个解答不会匹配NIL UUID,即00000000-0000-0000-0000-000000000000。当然,参考的答案中也包含了可以匹配NIL和非NIL UUID的正则表达式。

0