两层遍历

  1. a = [[1],[2],[3],[4],[5]]
  2. [x for i in a for x in i]

输出结果:

image.png

总结:

从最终的输出结果来看
第一个x代表着最终的输出,
从左向右第一个for是对a的最外层的遍历
第二个for是对第二层的遍历即对i的遍历,
但是输出是根据第二层的x进行输出的

三层遍历也是同样的原理

  1. list_test = [
  2. [
  3. [1,2,3],
  4. [4,5,6]
  5. ],
  6. [
  7. [7,8,9]
  8. ]
  9. ]
  10. # 三层也是同样的道理
  11. [x for i in list_test for j in i for x in j]

输出结果:

image.png

i in a for i in b结构

  1. # 查找字典交集
  2. def intersect_dicts(da, db, exclude=()):
  3. # Dictionary intersection of matching keys and shapes, omitting 'exclude' keys, using da values
  4. # 返回da和db中的键一样的 值的shape一样的 如果有exclude这个可能就清空了即返回的字典可能是个空字典
  5. return {k: v for k, v in da.items() if k in db and not any(x in k for x in exclude)}
  6. a = {'name': "jjw", "age": 18, "sex": 'boy'}
  7. b = {'name': "jjw", "age": 19, "height": 175}
  8. print(intersect_dicts(a, b))
  9. print(intersect_dicts(a, b, 'age'))
  10. c = [1, 2, 3, 4, 5]
  11. d = [1, 2, 5, 6]
  12. print([i in c for i in d]) # 意思就是判断c中的每个元素是否也在d中
  13. print(any([i in c for i in d])) # 任何一个成立就成立
  14. print(not any([i in c for i in d])) # 所有都不成立才返回TRUE
  15. e = [7, 8, 9]
  16. print(not any([i in c for i in e])) # 所有都不成立才返回TRUE