python中有種獨特的語法:推導式,能夠將代碼壓縮到1行,可是不使用也不影響。python
有三種:列表、字典、集合(注意沒有元組推導式)app
列表推導式函數
# 一、一行代碼實現1—100之和(知識點:列表推導式) print(sum([x for x in range(1, 101)])) # 解釋: # 列表推導式語句用[]包圍,[]中先執行for循環語句,將每次循環取得的值再執行for語句以前的表達式,而後將結果放入列表中,至關於以下語句 li = [] for x in range(1, 101): li.append(x) print(li) print(sum(li)) # 列表推導式還支持更復雜的語句,核心是用[]將生成列表的邏輯封裝起來 # 求1-100以內能被4整除,可是不能被5整除的全部數 print([x for x in range(1, 101) if x % 4 == 0 and x % 5 != 0]) # 多重循環,先執行一次外層循環,再循環內層遍歷全部元素 li = [a + b for a in '123' for b in 'abc'] # 輸出 ['1a', '1b', '1c', '2a', '2b', '2c', '3a', '3b', '3c'] # 更多用法 li2 = [k+':'+v for k, v in {'name': 'kobe', 'age': '41'}.items()] # 輸出 ['age:41', 'name:kobe'] # 問題:有兩個列表a和b,找出在a中但不在b中的元素(a有b沒有),在a和b中都存在的元素(ab都有),a和b中不一樣的元素(a有b沒有,b有a沒有) a = [1, 2, 3, 4, 5] b = [3, 4, 5, 6, 7] # 在a中但不在b中的元素(a有b沒有) li1 = [x for x in a if x not in b] print(li1) # 在a和b中都存在的元素(ab都有) li2 = [x for x in a if x in b] print(li2) # a和b中不一樣的元素(a有b沒有,b有a沒有) li3 = [x for x in a+b if x not in li2] print(li3)
字典推導式spa
# 字典推導式(用花括號{}包圍起來) dict = {x: x*x for x in [1, 2, 3]} # 輸出 {1: 1, 2: 4, 3: 9}
集合推導式code
# 集合推導式(也是用花括號包圍,和字典推導式區別只是在for語句的前面表達式不同,沒有:) s = {x for x in 'agjsgnjkjg' if x not in 'sgjkajhag'} print(type(s))
元素推導式(沒有)blog
# 元組推導式????(既然列表推導式用[],字典和集合推導式用{},那元組推導式固然用()了) # 對不起麼有元組推導式,圓括號在Python中被用做生成器的語法了 tup = (x for x in [1,2,3]) print(type(tup)) # 輸出:<class 'generator'>,能夠看到是一個生成器 # 若是非要按照上面的規律生成元組,須要顯式的調用元組轉換函數tuple() tup = tuple((x for x in [1,2,3])) print(tup) print(type(tup)) # 輸出: # (1, 2, 3) # <class 'tuple'>