[英]Python like sed using regexes
假设我有:
string= '{'id': '1'}'
现在使用像Perl / sed这样的字符串,我想
string=id
(在Perl中,它看起来像是string =〜s / {\\'([a-zA-Z0-9] )\\'。 $)/ \\ 1 /)
您能否给我一些见识,如何在python中做到这一点? 我希望regex语法相似,但是我不确定python语法以及应该使用什么导入,我是Python的初学者:)非常感谢:-)
在Python中,您可以使用re
模块进行正则表达式操作。 我对您的正则表达式做了一些修改,但是通常,这是可以在python中完成正则表达式替换的方式:
>>> import re
>>> s = "{'id': '1'}"
>>> re.sub(r"{'([^\']*)'.*$", r'\1', string)
'id'
sub()
函数首先接受正则表达式,然后接受替换,最后接受字符串。 re模块的文档提供了更多信息: http : //docs.python.org/library/re.html
作为参数传递的字符串的r
前缀基本上告诉Python将其视为“原始”字符串,其中大多数反斜杠转义序列都不会被解释。
首先,我同意@PenguinCoder:由于这是有效的JSON,因此您应该真正考虑只使用Python支持来处理JSON。
我去了Google并输入了关键字: Python regular expressions
以下是排名前两名的热门歌曲:
http://docs.python.org/library/re.html
http://docs.python.org/howto/regex.html
如果您阅读它们,将找到答案。
这是工作代码:
import re
s = '''string= "{'id': '1'}"'''
pat = re.compile(r"\s*([^=]+)\s*=[\s'\"]*{\s*'([^']+)'")
m = pat.match(s)
if m is not None:
id = m.group(1)
name = m.group(2)
result = "%s=%s" % (id, name)
# note: could also do this: result = "%s=%s" % m.groups()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.