list和dict的遍历和方法
程序员文章站
2022-05-25 16:06:38
...
每个人在使用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()
本文转自:http://www.cnblogs.com/icejoywoo/p/3531869.html
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()
本文转自:http://www.cnblogs.com/icejoywoo/p/3531869.html
上一篇: MS的一些小工具
下一篇: mac上 tensorflow 安装