python 内置类型遍历
遍历字典 dict 使用 items() 函数, 可以同时拿到 key 和 对应的 value 值:
# 测试
dict_name = {'id': 1, 'name': 'gnn_explorer'}
for k, v in dict_name.items():
print(k, v)
# 运行结果
"""
id 1
name gnn_explorer
"""
遍历序列 Sequence Types — list, tuple, range 使用 enumerate() 函数, 可以同时拿到索引和对应的 value 值:
# 测试
for i, v in enumerate(['g', 'n', 'n']):
print(i, v)
# 运行结果
"""
0 g
1 n
2 n
"""
同时遍历多个序列, 可以使用 zip() 函数:
# 测试
list_id = [1, 2]
list_name = ['gnn', 'fy']
for i, n in zip(list_id, list_name):
print(i, n)
# 运行结果
"""
1 gnn
2 fy
"""
反向遍历序列, 调用 reversed() 函数:
# 测试
# range(1, 6, 2) => (1, 3, 5)
for v in reversed(range(1, 6, 2)):
print(v)
# 运行结果
"""
5
3
1
"""
遍历排序之后的序列, 使用 sorted() 函数, 传入的 list 不变 :
# 测试
list_name = ['gnn', 'gnn', 'fy']
for n in sorted(set(list_name)):
print(n)
# 运行结果
"""
fy
gnn
"""
创建新的 list 去接收遍历的值的有时候更简单安全:
# 测试
import math
list_float = [1, 2, 3, float('NaN'), 5]
list_filter = []
for v in list_float:
if not math.isnan(v):
list_filter.append(v)
print(list_filter)
# 运行结果
"""
[1, 2, 3, 5]
"""
当然也可以用 列表推导式 ( list comprehension ) 来完成:
# list comprehension 测试
import math
list_float = [1, 2, 3, float('NaN'), 5]
list_filter = [v for v in list_float if not math.isnan(v)]
print(list_filter)
# 运行结果同上
其他方式, 内置函数 filter 也可以完成此功能, 其中涉及到 lambda 表达式 的用法:
# 内置函数 filter 测试
import math
list_float = [1, 2, 3, float('NaN'), 5]
list_filter = list(filter(lambda v: not math.isnan(v), list_float))
print(list_filter)
# 运行结果同上