首页 > python dict vs ruby hash

python dict vs ruby hash

ruby中的Hash用法

grades = Hash.new
grades["Dorothy Doe"] = 9

参考:http://ruby-doc.org/core-2.0/Hash.htm...

python中的dict用法

>>> a = dict(one=1, two=2, three=3)
>>> b = {'one': 1, 'two': 2, 'three': 3}
>>> c = dict(zip(['one', 'two', 'three'], [1, 2, 3]))
>>> d = dict([('two', 2), ('one', 1), ('three', 3)])
>>> e = dict({'three': 3, 'one': 1, 'two': 2})
>>> a == b == c == d == e
True

参考:http://docs.python.org/2/library/stdt...

问题

如果想像ruby那样进行这样的操作:

grades["a"] << 1
grades["b"] << 2
grades["c"] << 3
...

python怎么做?

如果用这种方式:

b = {'one': 1, 'two': 2, 'three': 3}

值是唯一的,但想要'one','two','three'的数组,那里面装很多不同的值。


好的,把评论里的内容整理一下:

搜索了相关的rubydoc和stackoverflow,帖主漏掉了一句初始化代码:

grades = Hash.new([])

然后做

grades["a"] << 1
grades["b"] << 2
grades["c"] << 3

才是合理的语法。
结果参见: http://stackoverflow.com/questions/93...

原因是 grades["a"].objectIdgrades["b"].objectId 相同,均为那个默认值的对象: []

python里没有对应操作,楼主@ithelloworld7 自己提到可以用 grades.setdefault('a', []).append(1),实际上仍然不太一样。因为python的默认值是对每一个key设置的,除非将默认值对象引用本身保存一下,才可以达到相同效果:

default = []
grades = {}
grades.setdefault('a', default).append(1)
grades.setdefault('b', default).append(2)
grades.setdefault('c', default).append(3)
print grades
//{'a': [1, 2, 3], 'b': [1, 2, 3], 'c': [1, 2, 3]}

python和ruby相同点是,一切均为对象。对于这个问题的不同点主要在于dict/Hash的api不同导致。

【热门文章】
【热门文章】