串列是Python中使用最多的一種資料結果,如何高效操作串列是提高代碼運行效率的關鍵,這篇文章列出了10個常用的串列操作,希望對你有幫助,
注意:很多人學Python程序中會遇到各種煩惱問題,沒有人幫答疑,為此小編建了個Python全堆疊免費答疑交流.裙 :一久武其而而流一思(數字的諧音)轉換下可以找到了,不懂的問題有老司機解決里面還有最新Python教程專案可拿,,一起相互監督共同進步!
1、迭代串列時如何訪問串列下標索引
普通版:
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開始:
for index, item in enumerate(items, start=1):
print(index, "-->", item)
>>>
1 --> 8
2 --> 23
3 --> 45
2、append 與 extend 方法有什么區別
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)
3、檢查串列是否為空
普通版:
if len(items) == 0:
print("空串列")
或者
if items == []:
print("空串列")
優雅版:
if not items:
print("空串列")
4、如何理解切片
切片用于獲取串列中指定范的子集,語法非常簡單
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]
5、如何拷貝一個串列物件
第一種方法:
new_list = old_list[:]
第二種方法:
new_list = list(old_list)
第三種方法:
import copy
# 淺拷貝
new_list = copy.copy(old_list)
# 深拷貝
new_list = copy.deepcopy(old_list)
6、如何獲取串列中的最后一個元素
索引串列中的元素不僅支持正數還支持負數,正數表示從串列的左邊開始索引,負數表示從串列的右邊開始索引,獲取最后一個元素有兩種方法,
>>> a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
>>> a[len(a)-1]
10
>>> a[-1]
10
7、如何對串列進行排序
串列排序有兩種方式,一種是串列自帶的方式 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}]
8、如何移除串列中的元素
洗掉串列中的元素有三種方式
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
9、如何連接兩個串列
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)
10、如何隨機獲取串列中的某個元素
import random
items = [8, 23, 45, 12, 78]
>>> random.choice(items)
78
>>> random.choice(items)
45
>>> random.choice(items)
12
注意:很多人學Python程序中會遇到各種煩惱問題,沒有人幫答疑,為此小編建了個Python全堆疊免費答疑交流.裙 :一久武其而而流一思(數字的諧音)轉換下可以找到了,不懂的問題有老司機解決里面還有最新Python教程專案可拿,,一起相互監督共同進步!
本文的文字及圖片來源于網路加上自己的想法,僅供學習、交流使用,不具有任何商業用途,著作權歸原作者所有,如有問題請及時聯系我們以作處理,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/191486.html
標籤:Python
