列表是Python中使用最多的一種數據結果,如何高效操做列表是提升代碼運行效率的關鍵,這篇文章列出了10個經常使用的列表操做,但願對你有幫助。app
普通版:dom
items = [8, 23, 45] for index in range(len(items)): print(index, "-->", items[index]) >>> 0 --> 8 1 --> 23 2 --> 45
優雅版:函數
for index, item in enumerate(items): print(index, "-->", item) >>> 0 --> 8 1 --> 23 2 --> 45
enumerate 還能夠指定元素的第一個元素從幾開始,默認是0,也能夠指定從1開始:code
for index, item in enumerate(items, start=1): print(index, "-->", item) >>> 1 --> 8 2 --> 23 3 --> 45
append表示把某個數據當作新元素追加到列表的最後面,它的參數能夠是任意對象對象
x = [1, 2, 3] y = [4, 5] x.append(y) print(x) >>> [1, 2, 3, [4, 5]]
extend 的參數必須是一個可迭代對象,表示把該對象裏面的全部元素逐個地追加到列表的後面排序
x = [1, 2, 3] y = [4, 5] x.extend(y) print(x) >>> [1, 2, 3, 4, 5] # 等價於: for i in y: x.append(i)
普通版:索引
if len(items) == 0: print("空列表") 或者 if items == []: print("空列表")
優雅版:rem
if not items: print("空列表")
切片用於獲取列表中指定範的子集,語法很是簡單get
items[start:end:step] 從 start 到 end-1 位置之間的元素。step 表示步長,默認爲1,表示連續獲取,若是 step 爲 2 就表示每隔一個元素獲取。 a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] >>> a[3:8] # 第3到第8位置之間的元素 [4, 5, 6, 7, 8] >>> a[3:8:2] # 第3到第8位置之間的元素,每隔一個元素獲取 [4, 6, 8] >>> a[:5] # 省略start表示從第0個元素開始 [1, 2, 3, 4, 5] >>> a[3:] # 省略end表示到最後一個元素 [4, 5, 6, 7, 8, 9, 10] >>> a[::] # 都省略至關於拷貝一個列表,這種拷貝屬於淺拷貝 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
第一種方法:it
new_list = old_list[:]
第二種方法:
new_list = list(old_list)
第三種方法:
import copy # 淺拷貝 new_list = copy.copy(old_list) # 深拷貝 new_list = copy.deepcopy(old_list)
索引列表中的元素不只支持正數還支持負數,正數表示從列表的左邊開始索引,負數表示從列表的右邊開始索引,獲取最後一個元素有兩種方法。
>>> a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] >>> a[len(a)-1] 10 >>> a[-1] 10
列表排序有兩種方式,一種是列表自帶的方式 sort,一種是內建函數 sorted。複雜的數據類型可經過指定 key參數進行排序。由字典構成的列表,根據字典元素中的age字段進行排序:
items = [{'name': 'Homer', 'age': 39}, {'name': 'Bart', 'age': 10}, {"name": 'cater', 'age': 20}] items.sort(key=lambda item: item.get("age")) print(items) >>> [{'age': 10, 'name': 'Bart'}, {'age': 20, 'name': 'cater'}, {'age': 39, 'name': 'Homer'}]
列表有 sort方法,用於對原列表進行從新排序,指定 key 參數,key 是匿名函數,item 是列表中的字典元素,咱們根據字典中的age進行排序,默認是按升序排列,指定 reverse=True 按降序排列
items.sort(key=lambda item: item.get("age"), reverse=True) >>> [{'name': 'Homer', 'age': 39}, {'name': 'cater', 'age': 20}, {'name': 'Bart', 'age': 10}]
若是不但願改變原列表,而是生成一個新的有序列表對象,那麼能夠內置函數 sorted ,該函數返回新列表
items = [{'name': 'Homer', 'age': 39}, {'name': 'Bart', 'age': 10}, {"name": 'cater', 'age': 20}] new_items = sorted(items, key=lambda item: item.get("age")) print(items) >>> [{'name': 'Homer', 'age': 39}, {'name': 'Bart', 'age': 10}, {'name': 'cater', 'age': 20}] print(new_items) >>> [{'name': 'Bart', 'age': 10}, {'name': 'cater', 'age': 20}, {'name': 'Homer', 'age': 39}]
刪除列表中的元素有三種方式
remove 移除某個元素,並且只能移除第一次出現的元素
>>> a = [0, 2, 2, 3] >>> a.remove(2) >>> a [0, 2, 3] # 若是要移除的元素不在列表中,則拋出 ValueError 異常 >>> a.remove(7) Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: list.remove(x): x not in list· del 根據指定的位置移除某元素 >>> a = [3, 2, 2, 1] # 移除第一個元素 >>> del a[1] [3, 2, 1] # 當超出列表的下表索引時,拋出IndexError的異常 >>> del a[7] Traceback (most recent call last): File "<stdin>", line 1, in <module> IndexError: list assignment index out of range
pop 與del 相似,可是 pop 方法能夠返回移除的元素
>>> a = [4, 3, 5] >>> a.pop(1) 3 >>> a [4, 5] # 一樣,當超出列表的下表索引時,拋出IndexError的異常 >>> a.pop(7) Traceback (most recent call last): File "<stdin>", line 1, in <module> IndexError: pop index out of range
listone = [1, 2, 3] listtwo = [4, 5, 6] mergedlist = listone + listtwo print(mergelist) >>> [1, 2, 3, 4, 5, 6]
列表實現了 + 的運算符重載,使得 + 不只支持數值相加,還支持兩個列表相加,只要你實現了 對象的 __add__操做,任何對象均可以實現 + 操做,例如:
class User(object): def __init__(self, age): self.age = age def __repr__(self): return 'User(%d)' % self.age def __add__(self, other): age = self.age + other.age return User(age) user_a = User(10) user_b = User(20) c = user_a + user_b print(c) >>> User(30)
import random items = [8, 23, 45, 12, 78] >>> random.choice(items) 78 >>> random.choice(items) 45 >>> random.choice(items) 12