Python 索引迭代

1、使用enumerate函数

  1. = ['Adam', 'Lisa', 'Bart', 'Paul']

  2. for index, name in enumerate(L):

  3.     print index + 1, '-', name.lower()

2、使用zip函数
  1. for index, name in zip(range(1, len(L)+1), L):

  2.     print index, '-', name

3、dict元素迭代访问

  1. d = {
  2. 'Adam': 95,
  3. 'Lisa': 85,
  4. 'Bart': 59
  5. }
  6. for (key, value) in d.items():
  7. print("%s: %s" % (key, value))
  8. for key in d:
  9. print("%s: %s" % (key, d[key]))
  10. for key, value in zip(d.keys(), d.values()):
  11. print("%s: %s" % (key, value))
如果仔细阅读Python的文档,还可以发现,dict除了values()方法外,还有一个 itervalues() 方法,用 itervalues() 方法替代 values() 方法,迭代效果完全一样。
  1. for key, value in zip(d.iterkeys(), d.itervalues()):
  2. print("%s: %s" % (key, value))

那这两个方法有何不同之处呢?

1. values() 方法实际上把一个 dict 转换成了包含 value 的list。

2. 但是 itervalues() 方法不会转换,它会在迭代过程中依次从 dict 中取出 value,所以 itervalues() 方法比 values() 方法节省了生成 list 所需的内存。

3. 打印 itervalues() 发现它返回一个 <dictionary-valueiterator> 对象,这说明在Python中,for 循环可作用的迭代对象远不止 list,tuple,str,unicode,dict等,任何可迭代对象都可以作用于for循环,而内部如何迭代我们通常并不用关心。 





posted @ 2015-12-14 21:37  指上弹兵赵小括  阅读(213)  评论(0编辑  收藏  举报