每个人在使用python的过程中都会遍历list和dict.
List遍历
最常用最简单的遍历list的方法
1 2 3 4 5 | a = [ "a" , "b" , "c" , "d" ] # simple iterate for i in a: print i |
但是, 如果我需要拿到list的index, 很多人可能会这样写
1 2 3 4 5 | a = [ "a" , "b" , "c" , "d" ] # index & value for i in xrange ( len (a)): print i, a[i] |
其实, python提供了一个方法enumerate, 用法如下
1 2 3 4 5 | a = [ "a" , "b" , "c" , "d" ] # iterate with index for i, el in enumerate (a): print i, el |
上面两种方式的结果相同
1 2 3 4 | 0 a 1 b 2 c 3 d |
这是一种更加方便便捷的方式, 虽然少写不了几个字符, 从代码可读性等方面来考量的话, 还是清晰很多的.
代码应该让人一目了然, 目的明确, 如果多种方式可以实现相同的功能, 那么我们应该选择一种大家更加容易理解的, enumerate就是这样的方式.
1 | enumerate (iterable[, start]) - > iterator for index, value of iterable |
第二个参数在很多时候也是很有用的, 比如我不希望从0开始, 希望从1开始
1 2 3 4 5 | a = [ "a" , "b" , "c" , "d" ] # iterate with index for i, el in enumerate (a, 1 ): print i, el |
输出如下
1 2 3 4 | 1 a 2 b 3 c 4 d |
如果你使用range的话, 会蹩脚很多.
Dict遍历
dict最简单的遍历方式
1 2 3 4 5 6 7 | d = { 'a' : 1 , 'c' : 3 , 'b' : 2 , 'd' : 4 } for k in d: print k for k in d: print k, d[k] |
上面遍历k和v的方式并不好, 显得很蹩脚. dict本身提供了iteritems()方法, 可以做到k,v对遍历.
1 2 3 4 5 | d = { 'a' : 1 , 'c' : 3 , 'b' : 2 , 'd' : 4 } # d.viewitems() for k, v in d.iteritems(): print k, v |
dict还有个viewitems方法, 这个直接看到的是全部k,v对.
iteritems和viewitems的区别是什么? 可以类比range和xrange的区别.
大家肯定都了解range和xrange的区别, 在遍历的时候尽量使用xrange, 特别是当遍历的范围比较大的时候.
1 2 3 4 5 6 7 8 | In [ 1 ]: print range ( 10 ) [ 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 ] In [ 2 ]: print xrange ( 10 ) xrange ( 10 ) In [ 3 ]: print type ( xrange ( 10 )) < type 'xrange' > |
range是直接返回一个保存全量数据的list, 空间复杂度是O(n), 而xrange是在遍历中不断生成的, 遍历的效率更高, 而且空间复杂度是O(1) (个人理解, 没看过具体实现).
iteritems和viewitems都可以完成遍历, 二者的不同用下面的代码来说明
1 2 3 4 5 6 7 8 | d = { 'a' : 1 , 'c' : 3 , 'b' : 2 , 'd' : 4 } # d.viewitems() for k, v in d.iteritems(): print k, v print type (d.viewitems()), type (d.itervalues()) print d.viewitems(), d.itervalues() |
输出如下
1 2 3 4 5 6 | a 1 c 3 b 2 d 4 < type 'dict_items' > < type 'dictionary-valueiterator' > dict_items([( 'a' , 1 ), ( 'c' , 3 ), ( 'b' , 2 ), ( 'd' , 4 )]) <dictionary - valueiterator object at 0x103d028e8 > |
viewitems直接返回的是[('a', 1), ('c', 3), ('b', 2), ('d', 4)], 熟悉dict构造函数的人应该知道, 这也是一种构造dict的方式.
1 2 | d = dict ( zip (( "a" , "b" , "c" , "d" ), ( 1 , 2 , 3 , 4 ))) # d = {'a': 1, 'c': 3, 'b': 2, 'd': 4} |
dict还有其他几个方法
1 2 3 4 | In [ 10 ]: import itertools In [ 11 ]: [" ".join(i) for i in itertools.product((" iter ", " view "), (" keys ", " values ", " items"))] Out[ 11 ]: [ 'iterkeys' , 'itervalues' , 'iteritems' , 'viewkeys' , 'viewvalues' , 'viewitems' ] |
dict的完整示例代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | d = dict ( zip (( "a" , "b" , "c" , "d" ), ( 1 , 2 , 3 , 4 ))) # d = {'a': 1, 'c': 3, 'b': 2, 'd': 4} for k in d: print k # d.viewkeys() for k in d.iterkeys(): print k print type (d.viewkeys()), type (d.iterkeys()) print d.viewkeys(), d.iterkeys() # d.viewvalues() for v in d.itervalues(): print v print type (d.viewvalues()), type (d.itervalues()) print d.viewvalues(), d.itervalues() # d.viewitems() for k, v in d.iteritems(): print k, v print type (d.viewitems()), type (d.itervalues()) print d.viewitems(), d.itervalues() |