在Python中将以分号分隔的string拆分为字典

我有一个string,看起来像这样:

"Name1=Value1;Name2=Value2;Name3=Value3" 

在Python中是否有一个内置的类/函数将采取该string并构造一个字典,就像我已经这样做了:

 dict = { "Name1": "Value1", "Name2": "Value2", "Name3": "Value3" } 

我已经查看了可用的模块,但似乎无法find任何匹配的东西。


谢谢,我自己也知道如何编写相关的代码,但是由于这种小巧的解决scheme通常是等待发生的矿井(即有人写道:Name1 ='Value1 = 2')等等,testingfunction。

那么我会自己做。

没有内build的,但你可以用一个生成器的理解相当简单地做到这一点:

 s= "Name1=Value1;Name2=Value2;Name3=Value3" dict(item.split("=") for item in s.split(";")) 

[编辑]从你的更新,你表明你可能需要处理报价。 这确实使事情复杂化,取决于你正在寻找的确切格式是什么(引用字符被接受,什么逃逸字符等)。 你可能想看看csv模块,看它是否可以覆盖你的格式。 下面是一个例子:(请注意,这个例子中的API有点笨拙,因为CSV被devise为遍历一系列logging,因此我只是看第一行的.next()调用。满足您的需求):

 >>> s = "Name1='Value=2';Name2=Value2;Name3=Value3" >>> dict(csv.reader([item], delimiter='=', quotechar="'").next() for item in csv.reader([s], delimiter=';', quotechar="'").next()) {'Name2': 'Value2', 'Name3': 'Value3', 'Name1': 'Value1=2'} 

根据格式的确切结构,您可能需要编写自己的简单parsing器。

这接近做您想要的:

 >>> import urlparse >>> urlparse.parse_qs("Name1=Value1;Name2=Value2;Name3=Value3") {'Name2': ['Value2'], 'Name3': ['Value3'], 'Name1': ['Value1']} 

它可以通过string连接和列表理解简单地完成

','。join(['%s =%s'%x for d in d.items()])

 >>d = {'a':1, 'b':2} >>','.join(['%s=%s'%x for x in d.items()]) >>'a=1,b=2' 

如果你的Value1,Value2只是实际值的占位符,你也可以使用dict()函数和eval()

 >>> s= "Name1=1;Name2=2;Name3='string'" >>> print eval('dict('+s.replace(';',',')+')') {'Name2: 2, 'Name3': 'string', 'Name1': 1} 

这是因为dict()函数理解语法dict(Name1=1, Name2=2,Name3='string') 。 string中的空格(例如每个分号之后)被忽略。 但请注意,string值需要引用。

 easytiger $ cat test.out test.py | sed 's/^/ /' p_easytiger_quoting:1.84563302994 {'Name2': 'Value2', 'Name3': 'Value3', 'Name1': 'Value1'} p_brian:2.30507516861 {'Name2': 'Value2', 'Name3': "'Value3'", 'Name1': 'Value1'} p_kyle:7.22536420822 {'Name2': ['Value2'], 'Name3': ["'Value3'"], 'Name1': ['Value1']} import timeit import urlparse s = "Name1=Value1;Name2=Value2;Name3='Value3'" def p_easytiger_quoting(s): d = {} s = s.replace("'", "") for x in s.split(';'): k, v = x.split('=') d[k] = v return d def p_brian(s): return dict(item.split("=") for item in s.split(";")) def p_kyle(s): return urlparse.parse_qs(s) print "p_easytiger_quoting:" + str(timeit.timeit(lambda: p_easytiger_quoting(s))) print p_easytiger_quoting(s) print "p_brian:" + str(timeit.timeit(lambda: p_brian(s))) print p_brian(s) print "p_kyle:" + str(timeit.timeit(lambda: p_kyle(s))) print p_kyle(s)