python dict能完成ruby中Hash的同样效果吗?,rubyhash,ruby中的Hash用法
python dict能完成ruby中Hash的同样效果吗?,rubyhash,ruby中的Hash用法
ruby中的Hash用法
grades = Hash.newgrades["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 == eTrue
参考:http://docs.python.org/2/library/stdt...
问题如果想像ruby那样进行这样的操作:
grades["a"] << 1grades["b"] << 2grades["c"] << 3...
python怎么做?
如果用这种方式:
b = {'one': 1, 'two': 2, 'three': 3}
值是唯一的,但想要'one','two','three'的数组,那里面装很多不同的值。
好的,把评论里的内容整理一下:
搜索了相关的rubydoc和stackoverflow,帖主漏掉了一句初始化代码:
grades = Hash.new([])
然后做
grades["a"] << 1grades["b"] << 2grades["c"] << 3
才是合理的语法。
结果参见: http://stackoverflow.com/questions/93...
原因是 grades["a"].objectId 与 grades["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不同导致。
编橙之家文章,
相关内容
- 请python大牛指点表单api上传403问题解法,python403,错误提
- Python图片处理用什么库能把文档/白板照片变得更清晰,
- python中有什么方法可以完成增量更新及预测算法的实现
- pycharm unicode字符编码显示中文问题求助,pycharmunicode,再
- Python start事件读取xml Ignoring item: 'NoneType' object,ignori
- Python对XML大文件数据去重什么方法好,pythonxml文件数据
- Python项目运行找不到模块问题,python模块,背景在subli
- 求Python正则匹配高手帮我查下源码问题在哪里,python源
- 请问Flask开发应用nginx与uwsgi应该如何部署,flasknginx,使
- 想调用pymysql返回值中varchar内容怎么写,pymysqlvarchar,m
评论关闭