摘要:列表的樂趣標簽空格分隔文章的原文是刪除元素所有等于值的元素重復警告該方法不負責列表項的順序。
列表的樂趣
標簽(空格分隔): Python list
1 刪除元素 1.1 所有等于 X 值的元素文章的原文是 Fun with Lists
x = 4 a = [1, 2, 3, 4, 4, 5, 6, 1, 4] for i in range(a.count(x)): a.pop(a.index(x)) print(a) [1, 2, 3, 5, 6, 1]
a = [1, 2, 3, 4, 4, 5, 6, 1, 4] b = [v for v in a if v != x] print(b) [1, 2, 3, 5, 6, 1] print(a) [1, 2, 3, 4, 4, 5, 6, 1, 4]1.2 重復
警告!
該方法不負責列表項的順序。
a = [1, 2, 3, 4, 3, 5, 1, 6] b = list(set(a)) print(b) [1, 2, 3, 4, 5, 6]1.3 第一個元素
a = [1, 2, 3, 4, 5, 6] b = a.pop(0) print(b) 1 print(a) [2, 3, 4, 5, 6]
a = [1, 2, 3, 4, 5, 6] del a[0] print(a) [2, 3, 4, 5, 6]
a = [1, 2, 3, 4, 5, 6] d = a[1:] print(d) [2, 3, 4, 5, 6] print(a) [1, 2, 3, 4, 5, 6]1.4 最后一個元素
a = [1, 2, 3, 4, 5, 6] b = a.pop() print(b) 6 print(a) [1, 2, 3, 4, 5]
a = [1, 2, 3, 4, 5, 6] del a[-1] print(a) [1, 2, 3, 4, 5]
a = [1, 2, 3, 4, 5, 6] c = a[:-1] print(c) [1, 2, 3, 4, 5] print(a) [1, 2, 3, 4, 5, 6]1.5 第 n 個元素
n = 3 a = [1, 2, 3, 4, 5, 6] b = a.pop(n - 1) print(b) 3 print(a) [1, 2, 4, 5, 6]
a = [1, 2, 3, 4, 5, 6] del a[n - 1] print(a) [1, 2, 4, 5, 6]
a = [1, 2, 3, 4, 5, 6] c = a[:n - 1] + a[n:] print(c) [1, 2, 4, 5, 6] print(a) [1, 2, 3, 4, 5, 6]
a = [1, 2, 3, 4, 5, 6] c = [v for i, v in enumerate(a) if i != n - 1] print(c) [1, 2, 4, 5, 6] print(a) [1, 2, 3, 4, 5, 6]2 替換元素 2.1 所有等于 x 值的元素
x = 4 a = [1, 2, 3, 4, 4, 5, 6, 1, 4] for i in range(a.count(x)): a[a.index(x)] = 0 print(a) [1, 2, 3, 0, 0, 5, 6, 1, 0]
a = [1, 2, 3, 4, 4, 5, 6, 1, 4] b = [v if v != x else 0 for v in a ] print(b) [1, 2, 3, 0, 0, 5, 6, 1, 0] print(a) [1, 2, 3, 4, 4, 5, 6, 1, 4]2.2 第一個元素
a = [1, 2, 3, 4] a[0] = 0 print(a) [0, 2, 3, 4]
a = [1, 2, 3, 4] b = [0] + a[1:] print(b) [0, 2, 3, 4] print(a) [1, 2, 3, 4]2.3 最后一個元素
a = [1, 2, 3, 4] a[-1] = 0 print(a) [1, 2, 3, 0]
a = [1, 2, 3, 4] b = a[:-1] + [0] print(b) [1, 2, 3, 0] print(a) [1, 2, 3, 4]2.4 第 n 個元素
n = 3 a = [1, 2, 3, 4] a[n - 1] = 0 print(a) [1, 2, 0, 4]
a = [1, 2, 3, 4] b = [v if i != n -1 else 0 for i, v in enumerate(a)] print(b) [1, 2, 0, 4] print(a) [1, 2, 3, 4]3 排序 3.1 按照字母順序排列地 (不分大小寫)
a = ["d", "C", "B", "a"] b = sorted(a, key=lambda x: x.lower()) print(b) ["a", "B", "C", "d"] print(a) ["d", "C", "B", "a"] a.sort(key=lambda s: s.lower()) print(a) ["a", "B", "C", "d"]3.2 按照字母順序排列地 (分大小寫)
a = ["d", "C", "B", "a"] b = sorted(a) print(b) ["B", "C", "a", "d"] print(a) ["d", "C", "B", "a"] a.sort() print(a) ["B", "C", "a", "d"]3.3 升序
a = ["a", "c", "d", "b"] b = sorted(a, reverse=True) print(b) ["d", "c", "b", "a"] print(a) ["a", "c", "d", "b"] a.sort(reverse=True) print(a) ["d", "c", "b", "a"]3.4 根據字符串長度
4 其他 4.1 列表中的所有值相加
a = ["aaaa", "B", "CCC", "dd"] b = sorted(a, key=lambda x: len(x)) print(b) ["B", "dd", "CCC", "aaaa"] print(a) ["aaaa", "B", "CCC", "dd"] a.sort(key=lambda x: len(x)) print(a) ["B", "dd", "CCC", "aaaa"]
a = [1, 2.5, 7, 13221, 4.6545] b = sum(a) print(b) 13236.15454.2 在列表中新增元素
a = [1, 2, 3] a.append(4) print(a) [1, 2, 3, 4]4.3 使函數對列表中的每個元素生效
def func(x): print(x) def func_2(x): return 2*x a = [1, 2, 3, 4] map(func, a) 1 2 3 4 b = map(func_2, a) print(b) [2, 4, 6, 8] c = [func_2(x) for x in a] print(c) [2, 4, 6, 8]4.4 兩個列表的笛卡爾積 (矢量)
a = [1, 2, 3] b = [4, 5, 6] c = [(x, y) for x in a for y in b] print(c) [(1, 4), (1, 5), (1, 6), (2, 4), (2, 5), (2, 6), (3, 4), (3, 5), (3, 6)]
import itertools d = [p for p in itertools.product(a, b)] print(d) [(1, 4), (1, 5), (1, 6), (2, 4), (2, 5), (2, 6), (3, 4), (3, 5), (3, 6)]4.5 n 個列表的笛卡爾積 (矢量)
from pprint import pprint import itertools a = [[0, 1], [2, 3], [4, 5]] b = [p for p in itertools.product(*a)] print(b) [(0, 2, 4), (0, 2, 5), (0, 3, 4), (0, 3, 5), (1, 2, 4), (1, 2, 5), (1, 3, 4), (1, 3, 5)]4.6 檢查兩個列表是否有一個共同的元素
a = [1, 2, 0] b = [3, 0, 4] d = len((set(a) & set(b))) > 0 print(d) True4.7 檢查一個列表是否包含值 x
a = [1, 2.5, 7, 13221, 4.6545] if 7 in a: print("yes") else: print("no") yes4.8 計算 x 出現在一個列表中的次數
a = [1, 2.5, 7, 13221, 4.6545, 7] b = a.count(7) print(b) 24.9 兩個列表的不同
a = [1, 2, 3, 4] b = [3, 4, 5, 6] c = [x for x in a if not x in b] print(c) [1, 2]
d = list(set(a) - set(b)) print(d) [1, 2]
e = list(set.difference(set(a), set(b))) print(e) [1, 2]4.10 n 個列表的不同
4.11 一個列表中首先出現的 n 個元素
a = [1, 2, 3, 4] b = [[3, 5, 6, 7], [1, 8, 9, 10]] a - b[0] - b[1]: c = [x for x in a if not any([x in l for l in b])] print(c) [2, 4] d = list(set(a).difference(*[set(l) for l in b])) print(d) [2, 4]
n = 2 a = [1, 2, 3, 4, 5, 6] b = a[:2] print(b) [1, 2]4.12 一個列表中首先出現的 n 個非 x 值的元素
n = 3 x = 2 a = [1, 2, 2, 3, 2, 2, 2, 4, 5, 6] gen = (v for v in a if v != x) b = [gen.next() for i in range(n)] print(b) [1, 3, 4] c = [] for v in a: if v != x: c.append(v) if len(c) == n: break print(c) [1, 3, 4] 4.13 Flatten a list of lists a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] b = [i for s in a for i in s] print(b) [1, 2, 3, 4, 5, 6, 7, 8, 9]4.14 把 x 插入 y 第一次出現之后的位置
x = 4 y = 3 a = [1, 2, 3, 5, 3, 6, 2] try: a.insert(a.index(y) + 1, x) except ValueError: a.append(x) print(a) [1, 2, 3, 4, 5, 3, 6, 2] a = [1, 2, 3, 5, 3, 6, 2] try: i = a.index(y) b = a[:i + 1] + [x] + a[i + 1:] except ValueError: b = a + [x] print(b) [1, 2, 3, 4, 5, 3, 6, 2] print(a) [1, 2, 3, 5, 3, 6, 2]4.15 把 x 插入 y 第一次出現之前的位置
x = 3 y = 4 a = [1, 2, 4, 5, 4, 6, 2] try: a.insert(a.index(y), x) except ValueError: a.append(x) print(a) [1, 2, 3, 4, 5, 4, 6, 2] a = [1, 2, 4, 5, 4, 6, 2] try: i = a.index(y) b = a[:i] + [x] + a[i:] except ValueError: b = a + [x] print(b) [1, 2, 3, 4, 5, 4, 6, 2] print(a) [1, 2, 4, 5, 4, 6, 2]4.16 兩個列表的相同元素
a = [1, 2, 3, 4] b = [3, 4, 5, 6] c = [x for x in a if x in b] print(c) [3, 4] d = list(set(a) & set(b)) print(d) [3, 4] e = list(set(a).intersection(b)) print(e) [3, 4]4.17 n 個列表的相同元素
a = [[1, 2, 3, 4], [3, 4, 5, 6], [1, 3, 7, 8]] b = list(set.intersection(*[set(l) for l in a])) print(b) [3] c = [x for x in a[0] if all([x in l for l in a[1:]])] print(c) [3]4.18 Iterate over every other element of a list
a = [1, 2, 3, 4, 5, 6] for x in a[::2]: print x 1 3 54.19 遍歷列表的索引/值對
a = [1, 2.5, 7, 13221, 4.6545] for i, v in enumerate(a): print("%i: %i" % (i, v)) 0: 1 1: 2 2: 7 3: 13221 4: 44.20 遍歷一個列表的元素
a = [1, 2, 3, 4] for x in a: print x 1 2 3 44.21 列表中最大的數
a = [1, 2.5, 7, 13221, 4.6545] b = max(a) print(b) 13221 4.22 Last n elements of a list n = 2 a = [1, 2, 3, 4, 5, 6] b = a[-2:] print(b) [5, 6]4.23 一個列表的長度
a = [1, 2, 3, 4] l = len(a) print(l) 44.24 合并兩個列表
a = [1, 2, 3] b = [4, 5, 6] c = a + b print(c) [1, 2, 3, 4, 5, 6] print(a) [1, 2, 3] print(b) [4, 5, 6] a.extend(b) print(a) [1, 2, 3, 4, 5, 6] print(b) [4, 5, 6]4.25 列表的組合
from pprint import pprint from itertools import permutations as perm a = ["a", "b", "c"] b = list(perm(a)) pprint(b) [("a", "b", "c"), ("a", "c", "b"), ("b", "a", "c"), ("b", "c", "a"), ("c", "a", "b"), ("c", "b", "a")] c = ["".join(p) for p in perm(a)] print(c) ["abc", "acb", "bac", "bca", "cab", "cba"] d = ["".join(p) for p in perm(a, 2)] print(d) ["ab", "ac", "ba", "bc", "ca", "cb"]4.26 Prepend an element to a list
a = [2, 3, 4] a.insert(0, 1) print(a) [1, 2, 3, 4] a = [2, 3, 4] b = [1] + a print(b) [1, 2, 3, 4] print(a) [2, 3, 4]4.27 列表反序
a = [1, 2, 3, 4] a.reverse() print(a) [4, 3, 2, 1] a = [1, 2, 3, 4] c = a[::-1] print(c) [4, 3, 2, 1] print(a) [1, 2, 3, 4]4.28 列表中最小的數字
a = [1, 2.5, 7, 13221, 4.6545] b = min(a) print(b) 14.29 2 個列表的對稱差
a = [1, 2, 3, 4] b = [3, 4, 5, 6] c = [x for x in a if x not in b] + [x for x in b if x not in a] print(c) [1, 2, 5, 6] d = list(set(a) ^ set(b)) print(d) [1, 2, 5, 6] e = list(set(a).symmetric_difference(b)) print(e) [1, 2, 5, 6]4.30 n 個列表的對稱差
a = [[1, 2, 3, 4], [3, 4, 5, 6], [1, 5, 7, 8]] b = a[0] for i in range(len(a) - 1): b = list(set(b) ^ set(a[i + 1])) print(b) [2, 6, 7, 8] tmp = {} for v in [i for s in a for i in s]: tmp[v] = (v not in tmp) c = [k for k, v in tmp.iteritems() if v] print(c) [2, 6, 7, 8]4.31 兩個列表的交集
a = [1, 2, 3, 4] b = [3, 4, 5, 6] c = [x for x in set(a + b)] print(c) [1, 2, 3, 4, 5, 6] d = list(set(a) | set(b)) print(d) [1, 2, 3, 4, 5, 6] e = list(set(a).union(b)) print(e) [1, 2, 3, 4, 5, 6]4.32 n 個列表的交集
a = [[1, 2, 3, 4], [3, 4, 5, 6], [1, 6, 7, 8]] b = list(set.union(*[set(l) for l in a])) print(b) [1, 2, 3, 4, 5, 6, 7, 8] import itertools c = [x for x in set(itertools.chain(*a))] print(c) [1, 2, 3, 4, 5, 6, 7, 8]4.33 列表的左邊加 0
max_length = 10 a = [1, 2, 3, 4] b = [0]*(max_length - len(a)) + a print(b) [0, 0, 0, 0, 0, 0, 1, 2, 3, 4]4.34 列表的右邊加 0
max_length = 10 a = [1, 2, 3, 4] b = a + [0]*(max_length - len(a)) print(b) [1, 2, 3, 4, 0, 0, 0, 0, 0, 0]
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/37453.html
摘要:當我想聊聊的是對于編程系統編程系統產品編程其實其中也有很多好玩的地方與神奇的景象。最重要的一點是,有助于他人,我很開心編程系統產品可能得到用戶的認可,且對其有所幫助。這就是編程,一個讓許多人痛苦掙扎卻又是一種樂趣和苦惱共存的創造性活動。 程序員是一個在你即將30、40隨時可能面臨高壓禿頂的工作,這是一個朋友在聽到我的新職業的第一反應。我也習以為常的笑笑敷衍過去。 現在高壓已經不是...
摘要:用了一段時間的和,忍無可忍之下幾乎要打算自己動手做一款編輯器了。客戶端元,客戶端元目前元,無任何功能添加。簡單易用,而功能又十分強大,除了很多精美的主題,豐富的開放接口,讓寫作和折騰的雙重快感可以同時擁有。 用了一段時間的 Ulysses 和 MWeb,忍無可忍之下幾乎要打算自己動手做一款 Markdown 編輯器了。還好,又遇到了 MarkEditor。 成本分析 首先,從各位客官最...
摘要:關于可參照張鑫旭大大的講解設置變化速度然后將方法里面的賦值去掉加上方法如下心形樣式可變化心形顏色加上隨機顏色的函數下面的屬性隨位移是變化的可添加你需要變化的樣式比如透明度縮放最后加上事件圖不會搞撒 2018年開工,大家都很清閑,隨意瀏覽各個社區,有些小發現,希望跟大家分享下,語言組織太差請忽略:大致效果:鼠標每次點擊頁面,鼠標處便出現一個?,然后?慢慢上升至消失。還是直接上代碼吧。 1...
閱讀 1416·2021-10-11 10:59
閱讀 3114·2019-08-30 15:54
閱讀 2735·2019-08-30 13:19
閱讀 2464·2019-08-30 13:02
閱讀 2377·2019-08-30 10:57
閱讀 3355·2019-08-29 15:40
閱讀 986·2019-08-29 15:39
閱讀 2311·2019-08-29 12:40