以前咱們已經學習了最簡單的列表推導式和生成器表達式。可是除此以外,其實還有字典推導式、集合推導式等等。數組
下面是一個以列表推導式爲例的推導式詳細格式,一樣適用於其餘推導式。函數
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(30) if i % 3 is 0] print(multiples) # Output: [0, 3, 6, 9, 12, 15, 18, 21, 24, 27]
例二:30之內全部能被3整除的數的平方code
def squared(x): return x*x multiples = [squared(i) for i in range(30) if i % 3 is 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 = {mcase[k]: k for k in mcase} print(mcase_frequency)
例二:合併大小寫對應的value值,將k統一成小寫字符串
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)
例:計算列表中每一個值的平方,自帶去重功能get
squared = {x**2 for x in [1, -1, 2]} print(squared) # Output: set([1, 4])
練習題:input
例1: 過濾掉長度小於3的字符串列表,並將剩下的轉換成大寫字母class
例2: 求(x,y)其中x是0-5之間的偶數,y是0-5之間的奇數組成的元祖列表
例3: 求M中3,6,9組成的列表M = [[1,2,3],[4,5,6],[7,8,9]]