除了咱們以前所學習的列表推導式和生成器表達式以外,還有字典推導式、集合推導式等等。python
下面就是一個以列表推導式爲例的推導式詳細格式,一樣適用於其餘推導式。函數
variable = [out_exp_res for out_exp in input_list if out_exp == 2] out_exp_res: 列表生成元素表達式,能夠是有返回值的函數。 for out_exp in input_list: 迭代input_list將out_exp傳入out_exp_res表達式中。 if out_exp == 2: 根據條件過濾哪些值能夠。
例一:30之內全部能被3整除的數學習
multiples = [i for i in range(31) if i % 3 == 0] print(multiples)
例二:30之內全部能被3整除的數的平方spa
multiples = [i ** 2 for i in range(31) if i % 3 == 0] print(multiples)
例三:找到嵌套列表中名字含有兩個「e「的全部名字blog
names = [['Tom', 'Billy', 'Jefferson', 'Andrew', 'Wesley', 'Steven', 'Joe'], ['Alice', 'Jill', 'Ana', 'Wendy', 'Jennifer', 'Sherry', 'Eva']] print([name for lst in names for name in lst if name.count('e') >= 2]) # 注意遍歷順序,這是實現的關鍵
例一:將一個字典的key和value對調ip
mcase = {'a': 10, 'b': 34} mcase_frequency = {value:key for key, value in mcase.items()} print(mcase_frequency)
例二:合併大小寫對應的value值,將k統一成小寫get
mcase = {'a': 10, 'b': 34, 'A': 7, 'Z': 3} mcase_frequency = {k.lower(): mcase.get(k.lower(), 0) + mcase.get(k.upper(), 0) for k in mcase.keys()} print(mcase_frequency)
例:計算列表中每一個值的平方,自帶去重功能input
squared = {x**2 for x in [1, -1, 2]} print(squared)