ruby中的Hash用法grades = Hash.new
grades["Dorothy Doe"] = 9python中的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 == eTrue如果想像ruby那樣進(jìn)行這樣的操作:grades["a"] << 1grades["b"] << 2grades["c"] << 3...python怎么做?如果用這種方式:b = {'one': 1, 'two': 2, 'three': 3}
1 回答

犯罪嫌疑人X
TA貢獻(xiàn)2080條經(jīng)驗(yàn) 獲得超4個(gè)贊
一句初始化代碼:
grades = Hash.new([])
然后做
grades["a"] << 1grades["b"] << 2grades["c"] << 3
才是合理的語(yǔ)法。
原因是 grades["a"].objectId
與 grades["b"].objectId
相同,均為那個(gè)默認(rèn)值的對(duì)象: []
python里沒(méi)有對(duì)應(yīng)操作,可以用 grades.setdefault('a', []).append(1)
,實(shí)際上仍然不太一樣。因?yàn)閜ython的默認(rèn)值是對(duì)每一個(gè)key設(shè)置的,除非將默認(rèn)值對(duì)象引用本身保存一下,才可以達(dá)到相同效果:
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相同點(diǎn)是,一切均為對(duì)象。對(duì)于這個(gè)問(wèn)題的不同點(diǎn)主要在于dict/Hash的api不同導(dǎo)致。
添加回答
舉報(bào)
0/150
提交
取消