摘要:接下來本文將從這四個方面來介紹列表的一些常用小技巧。可能有人會對這兩種拷貝存在疑問,他們得到的列表的形式不是一樣的嘛是的,它們在拷貝后得到的列表形式確實是一樣的。比較兩個列表是否是一樣的,這里的前提條件是這兩個列表對象不是同一個對象。
微信公眾號:冰咖啡與狗1. 列表
一杯冰咖啡,一條狗,一個碎碎念的程序員...
不同于 C++ 和 Java,在 Python 中,沒有在標準庫中內置數組類型,而是通常利用列表來表示數組,同時它也比數組的使用要靈活得太多。
列表是 Python 中最基本的數據結構,列表中的元素的存儲是有序的,所以我們可以直接利用索引去訪問列表中的值。在學習數據結構時,我們知道,對一個數據結構的操作,無外乎增刪改查四種。接下來本文將從這四個方面來介紹列表的一些常用小技巧。
1.1. 列表中的增對列表的增加操作有兩種,一種是創建一個新的列表,一種是在一個已有的列表中增加一個新元素。我們首先介紹如何創建一個新的列表:
# 創建一個空列表 list1 = [] # 創建一個默認值為0,長度為n的列表 list2 = [0] * n # 利用列表生成式創建列表 list3 = [i for i in range(10)] # 5*5 二維列表 list4 = [[i for i in range(5)] for j in range(5)] # 利用其他數據結構生成列表, list() 函數接收一個可迭代對象作為參數 tuple1 = (1, 2, 3) list5 = list(tuple1) # 字符串轉化為列表 str1 = "I love code" # 每個元素作為列表中的一個元素 list6 = list(str1) # 按照指定字符分割 list7 = str1.split(" ") # ["I", "love", "code"]
在編程過程中,有時我們需要對一個列表進行操作,但是列表是一個可變對象,對列表的操作往往會改變其本來的順序結構。因此,當我們不想改變列表原有的順序結構,我們需要對舊的列表進行一個拷貝,然后在新的列表上進行操作。拷貝存在兩種,淺拷貝和深拷貝。可能有人會對這兩種拷貝存在疑問,他們得到的列表的形式不是一樣的嘛?
是的,它們在拷貝后得到的列表形式確實是一樣的。但是在進行操作時,就會有很大的差別了,特別是當你的列表中存在可變對象時。我們只需要記住一點,淺拷貝只復制不可變對象,而深拷貝不僅復制不可變對象,還復制了可變對象。以下進行舉例說明:
# 如果一個列表中的元素都是不可變對象,可以直接用淺拷貝 list1 = [1, 2, "i"] list2 = list1[::1] # 淺拷貝 list3 = [i for i in list1] # 淺拷貝 import copy list4 = copy.copy(list1) # 淺拷貝 # 如果一個列表中的元素包含可變對象,要完成復制列表,需要用深拷貝 list5 = ["Will", 1, ["Python", "Java", "C++"]] list6 = copy.deepcopy(list5)
為什么在包含不可變對象的時候,需要用到深拷貝呢?
上面我們說過,淺拷貝只拷貝不可變對象。當列表中存在可變對象時,我們可以發現其引用 id 是一樣的,即它們是同一個對象,因此對 list5 的操作會影響到 list6 。而在深拷貝中,對于可變對象,在拷貝的新列表中會生成一個新的對象,所以對 list6 的修改不會影響到 list5 。
id(list5[2]) # 2195936916360 id(list6[2]) # 2195936916744
對列表的另一種增加操作就是在已有的列表的基礎上增加元素了,主要包括以下幾種操作:
list1 = ["I"] # 在列表尾部增加一個新元素 list1.append("love") # 合并兩個列表 list2 = ["Apple", 3] list1.extend(list2) # ["I", "love", "Apple", 3] list1 = list1 + list2 # ["I", "love", "Apple", 3] # 在指定位置插入元素 list1.insert(index=1, "not") # ["I", "not", "love", "Apple", 3]
對數據結構的刪除操作包括兩種,刪除整個列表,或者刪除列表中的某些元素。對于從內存中刪除整個列表,該操作十分簡單:
list1 = [1, 2, 3] del list1
對于刪除列表中的元素,同樣可以使用 del 語句,同時還可以使用 remove() 函數。
list1 = [1, 2, 3] print(list1) # [1, 2, 3] del list1[1] print(list1) # [1, 3] # 移除某個值的第一匹配項 list2 = [1, 2, 2, 3, 5] list2.remove(2) # 移除第一個值為 2 的元素
修改操作即在原有的列表的基礎上對其進行修改,上面以及介紹了增加和刪除操作,這里就對不改變元素的個數的操作進行介紹,主要包括排序和反轉列表等。
# 對一個整數列表進行排序 list1 = [9, 5, 6, 2, 7, 1, 3] # 升序排列 list1.sort() # [1, 2, 3, 5, 6, 7, 9] list1 = sorted(list1) # [1, 2, 3, 5, 6, 7, 9] # 降序排列 list1.sort(reverse=True) # [9, 7, 6, 5, 3, 2, 1] list1 = sorted(list1, reverse=True) # [9, 7, 6, 5, 3, 2, 1] # 指定鍵值排序 list1 = [("a", 3), ("b", 2), ("c", 1)] list1.sort(key=lambda x:x[1]) # [("c", 1), ("b", 2), ("a", 3)] ## 反轉列表,即將原來的列表逆序排列 list2 = [4, 2, 3, 1] list2 = list2[::-1] # [1, 3, 2, 4] list2.reverse() # [1, 3, 2, 4]
對列表的查找操作無外乎以下幾種:
遍歷列表;
查找指定索引的元素;
查找指定值的元素;
列表的遍歷方式有三種,分別是根據索引遍歷、根據值遍歷和 enumerate()遍歷。
list1 = ["Python", "C++", "Java"] # 方法 1 for i in range(len(list1)): print(list1[i]) # 方法 2 , 遍歷速度最高效,但是無法記錄索引 for i in list1: print(i) # 方法 3 for index, val in enumerate(list1): print(val)
查找元素有兩種,一種是按照索引查找,一種是遍歷按值查找。
# 查找指定索引的元素 list1 = [1, 3, 2, 5, 7, 8] list1[3] # 返回索引為 3 的元素,值為5 # 查找指定值的元素 key = 5 for i in list1: if i == key: print("OK") # 查找最大元素和最小元素 max(list1) # 8 min(list1) # 1
上述介紹了列表的增刪改查四種常用操作,當然對列表的操作不僅僅只有這些,例如還有兩個列表的比較,列表結構的轉化等等。
比較兩個列表是否是一樣的,這里的前提條件是這兩個列表對象不是同一個對象。
list5 = [("car", 1), ("bike", 2), ("foot", 3)] list6 = [("car", 1), ("bike", 2), ("foot", 3)] # 判斷兩個列表是否是同一個對象 list5 is list6 # False # 判斷兩個列表是否相等 list5 == list6 # True # 當列表中的元素很多,且結構復雜時,可以使用 numpy 模塊 import numpy as np a = np.array(list5) b = np.array(list6) (a == b).all() # True
列表結構的轉化主要包括將列表轉化為元組、集合、字符串和字典:
list1 = ["a", "b", "c", "d", "c"] # 列表轉化為元組 tuple1 = tuple(list1) # ("a", "b", "c", "d", "c") # 列表轉化為集合 set1 = set(list1) # {"a", "b", "c", "d"} # 列表轉化為字符串 str1 = "".join(list1) # "abcdc" # 列表轉化為字典,元素為 key, 次數為 value from collections import Counter, defaultdict dict1 = Counter(list1) # Counter({"a": 1, "b": 1, "c": 2, "d": 1}) # 或者 dict2 = defaultdict(int) for i in list1: dict2[i] += 1 dict2 # defaultdict(int, {"a": 1, "b": 1, "c": 2, "d": 1})
歡迎掃碼關注公眾號冰咖啡與狗,一起每日進步。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/43937.html
摘要:元組是靜態數組,它們不可變,且其內部數據一旦創建便無法改變。元組緩存于運行時環境,這意味著我們每次使用元組時無須訪問內核去分配內存。 以下是整理的JavaScript和python的基礎區別的整理: 字符串、列表、元組、字典、集合、函數 字符串 聲明一個字符串 python str = 123 str = 123 Tips: 如果是三個引號的話,那么在py中就是注釋的意思 ...
摘要:元組是靜態數組,它們不可變,且其內部數據一旦創建便無法改變。元組緩存于運行時環境,這意味著我們每次使用元組時無須訪問內核去分配內存。 以下是整理的JavaScript和python的基礎區別的整理: 字符串、列表、元組、字典、集合、函數 字符串 聲明一個字符串 python str = 123 str = 123 Tips: 如果是三個引號的話,那么在py中就是注釋的意思 ...
摘要:返回值,非必須,返回多個值使用逗號分隔即可。注意第一行末尾的分號無參數無返回值的函數該內容將演示函數的使用便捷性。函數的返回值可以賦值給一個變量,通過打印該變量,即可知道返回的具體內容。先學習一下局部變量與全局變量。 Python 學習的第一個難關 -- 函數,這個地方學會的人覺得沒有啥,沒學過的學的時候迷迷瞪...
摘要:在這里我分享下我個人入門機器學習的經歷,希望能對大家能有所幫助。相關學習鏈接,,入門后的體驗在入門了機器學習之后,在實際工作中,絕大多數的情況下你并不需要去創造一個新的算法。 機器學習在很多眼里就是香餑餑,因為機器學習相關的崗位在當前市場待遇不錯,但同時機器學習在很多人面前又是一座大山,因為發現它太難學了。在這里我分享下我個人入門機器學習的經歷,希望能對大家能有所幫助。 PS:這篇文章...
閱讀 3881·2021-11-24 11:14
閱讀 3321·2021-11-22 13:53
閱讀 3883·2021-11-11 16:54
閱讀 1546·2021-10-13 09:49
閱讀 1211·2021-10-08 10:05
閱讀 3392·2021-09-22 15:57
閱讀 1754·2021-08-16 11:01
閱讀 965·2019-08-30 15:55