① python列表中所有元素必須為相同類型的數據為啥是錯的
因為可以類型不同
② 深入理解python列表和元組
列表和元組都是一個可以放置任意數據類型的有序集合。這里需要注意三個詞,任意、有序、集合,其實就是說明列表和元組是可以放置任意數據類型,其次是有序的,另外,它是一個集合。
列表是動態的,它的長度大小不固定的,可以隨意的增加、刪除或者改變。
元組是靜態的,它的長度大小是固定的,無法增加、刪除或者改變。
列表是動態的、可變的,而元組是靜態的、不可變的。
列表的存儲方式,如下所示:
元組的存儲方式,如下所示:
存儲同樣的元素,元組使用的存儲空間更小,要少16個位元組。這是因為列表是動態的,所以列表中要存儲指針,來指向對應的元素。另外,列表是可變的,所以需要額外存儲已經分配的存儲信息,因為它要知道現在已經存儲了多少信息,還剩下多少,需不需要額外分配存儲空間等等。所以,列表多出來的存儲空間主要是:指針 + 存儲空間長度。
如下例子可以看到列表存儲空間的變化:
列表存儲空間變化:
從列表和元組的存儲方式可以得出,元組的性能是優於列表的。
元組和列表的初始化性能比較:
③ Python 列表內存淺析
序列是Python中最基本的數據結構。序列是一種數據存儲方式,用來存儲一系列的數據。
在內存中,序列就是一塊用來存放多個值的連續的內存空間。比如一個整數序列[10,20,30,40]
序列中的每個元素都分配一個數字 - 它的位置,或索引。第一個索引是0,第二個索引是1,依此類推。
列表:用於存儲任意數目、任意類型的數據集合。
列表是內置可變序列,是包含多個元素的有序連續的內存空間。列表定義的標准語法格式:
其中,10,20,30,40 這些稱為:列表a的元素。
列表中的元素可以各不相同,可以是任意類型。比如:a = [10,20,"abc",True,[]]
當列表增加元素時,列表會自動進行內存管理,減少了程序員的負擔。但是列表元素大量移動,效率低所以一般建議在尾部添加。
本地電腦運行結果:
列表是可變數據類型,地址不變,值可變。因此,添加新的值之後,地址也是不變的。
解析:在索引2處要引用50這個元素
申請了8個內存空間但是list實際用來存儲元素只使用了其中5個內存空間
insert的時間復雜度是O(n)
pop () 方法 刪除並返回指定位置的元素,如果未指定位置則默認操作
pop () 方法 刪除並返回指定位置的元素,如果未指定位置則默認操作
結果運行:
④ Python其實很簡單 第九章 列表與元組(一)
在前面,我們要保存一個數據,需要先定義一個變數,而且一個變數中只能保存一個數據。譬如,語句:a1=1,值「1」就被保存了,但要保存「2」,就還需要再定義一個變數:a2=2......這樣以來,隨著數據的增多,豈不是要定義更多的變數嗎?
可以使用一個新的數據類型,它記錄很多數據,並且將它們按照順序存儲在連續的內存空間中,這便是序列。Python中有5種常用的序列結構,分別是列表、元組、集合、字典和字元串。
9.1列表
語法格式:
listname=[element1,element2,element3,......,elementn]
其中,listname為列表名,element1,element2,element3,......,elementn表示列表中的元素。各個元素的數據類型可以相同,也可以不同,但通常元素的類型都是相同的,含義也是相同的。
如:
list1=[『風』,』馬『,』牛』,1,2,3,』a』,』b』,』c』]就沒有太多的實際用途。
list2=['張三','男',18,']雖然元素的類型不同,但表示了同一個人的信息。
1、訪問列表元素
列表中元素的索引號從0開始標記,訪問列表元素時,可以直接按照索引號讀取。
如:
list2=['張三','男',18,']
print(list2[1]) #輸出列表中索引號為1的元素
輸出結果:男
和字元串一樣,序列都是可以使用切片操作的。
如:
print(list2[:2])
輸出結果:['張三', '男']
print(list2[2:])
輸出結果:[18, ']
2、使用range()函數創建數值列表
格式:range(start, stop [,step]) ;start 指的是計數起始值,默認是 0;stop 指的是計數結束值,但不包括 stop ;step 是步長,默認為 1,不可以為 0 。range() 方法生成一段左閉右開的整數范圍。
可以使用range()函數創建數值列表,如:
list1=list(range(10,20,2))
print(list1)
運行結果:[10, 12, 14, 16, 18]
3、刪除列表
語法格式如下:
del listname
其中,listname為要刪除列表的名稱。
刪除列表與刪除變數的方法是完全一樣的,前面已經介紹過了。
4、遍歷列表
常用的遍歷列表的方法有是利用for語句,舉例如下:
list1=list(range(10))
for item in list1:
print(item,end=' ') # end=』 『表示以空格結束,如果不寫這個參數,相當於默認值end=』 』
輸出結果:0 1 2 3 4 5 6 7 8 9
為了獲取列表元素的索引值,就需要使用enumerate()函數。
list1=list(range(10,20,2))
for index,item in enumerate(list1):
print(index,'-',item,end=' ')
輸出結果:0 - 10 1 - 12 2 - 14 3 - 16 4 - 18
5、追加、修改和刪除列表元素
追加元素
>>> list1=['春','夏','秋']
>>> list1.append('冬')
>>> list1
['春', '夏', '秋', '冬']
還有一種方法,就是使用「+」號將兩個序列連接起來。如:
list1=['春','夏','秋']
list1=list1+['冬']
print(list1)
輸出結果為:['春', '夏', '秋', '冬']
注意,下面的做法是錯誤的:
>>> list1=['春','夏','秋']
>>> list1=list1+'冬'
Traceback (most recent call last):
File " ", line 1, in
list1=list1+'冬'
TypeError: can only concatenate list (not "str") to list
從這個提示可知,列表只能與列表連接,而不能與字元串連接。
修改元素
>>> list1[2]='autumn' #通過索引對元素直接賦值
>>> print(list1)
['春', '夏', 'autumn', '冬']
刪除元素
>>> del list1[2] #通過索引直接刪除元素
>>> print(list1)
['春', '夏', '冬']
6、列表元素排序
在討論列表元素排序時,為了將有序列表變成無序列表,這里用到了shuffle()函數,但它不是Python的內置函數,需要先使用import語句將random模塊包含進來,這樣才能像使用內置函數那樣使用擴展模塊中的函數。
>>> import random #導入random模塊
>>> list1=list(range(10)) #生成列表,元素為0到9的整數。
>>> list1
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> random.shuffle(list1) #用random包中的shuffle()函數將list1中元素次序打亂
>>> list1
[8, 6, 3, 5, 0, 7, 1, 9, 2, 4]
>>> list1.sort() #對list1升序排列
>>> list1
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> random.shuffle(list1) #將list1順序重新打亂
>>> list1
[5, 9, 7, 8, 4, 3, 2, 0, 6, 1]
>>> list1.sort(reverse=True) #對list1降序排列
>>> list1
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
方法sort()的語法格式:
listname.sort(key=None,reverse=False)
其中,listname表示要排序的列表;key表示指定一個鍵,如」key=str.lower」表示排序時不區分字母大小寫;reverse為True表示降序排列(為默認值,可省缺),為False表示升序排列。
還有一個函數sorted(),功能與方法sort()相似。格式如下:
sorted(listname,key=None,reverse=False)
7、 利用列表推導式快速生成一個列表
例1:生成指定范圍的數值列表。
>>> import random
>>> list1=[random.randint(0,20) for i in range(10)]
>>> list1
[16, 20, 19, 6, 5, 7, 10, 5, 12, 5] #生成了包含10個值在0到20之間的元素構成的列表。
例2:根據現有列表生成新的列表。
>>> radius=list(range(1,6)) #生成列表 radius保存半徑的值
>>> radius
[1, 2, 3, 4, 5]
>>> s=[round(2*3.14*r,2) for r in radius]
#生成列表s,將計算得到的周長值保存起來,其中round()可以保留指定小數位,格式 round(var, n),var為變數名,n為指定保留小數位。
>>> s
[6.28, 12.56, 18.84, 25.12, 31.4]
例3:從列表中選擇符合條件的元素組成新的列表。
>>> score=[98,65,77,56,82,89] #列表score用來存儲成績
>>> good=[x for x in score if x>=80]
#從列表score中選取>=80的元素存入新列表good中
>>> good
[98, 82, 89]
count()、index()和sum()方法
count()方法
用於統計指定元素在列表中出現的次數。
例:
>>> list1=['a','b','c','d','e','f','c','d','e','a','b','c','d']
>>> num=list1.count('c') #統計列表list1中'c'的個數
>>> num
3
index()方法
用於獲取指定元素在列表中第一次出現的索引值。
>>> list1=['a','b','c','d','e','f','c','d','e','a','b','c','d']
>>> position=list1.index('c')
>>> position
2
sum()方法
用於計算數值列表中全部或指定元素的和。
>>> list1=[1,2,3,4,5]
>>> total=sum(list1) #計算列表list1中全部元素的和
>>> total
15
>>> total=sum(list1,1) #在列表list1全部元素的和後,在加上參數(「1」)的值
>>> total
16
>>> total=sum(list1[:2]) #計算切片list1[:2]中各元素的和
>>> total
3
二維列表
格式:listname[下標1][下標2]
其中,listname表示列表的名稱,下標1表示列表中的行號,下標2表示列表中的列號。對於n行m列的二維列表,第一個元素的行號和列號都是0,最後一個元素的行號和列號都是n-1。如下所示:
list[0][0] list[0][1] list[0][2] ............ list[0][m-1]
list[1][0] list[1][1] list[1][2] ............ list[1][m-1]
......
......
list[n-1][0] list[n-1][1] list[n-1][2] ............ list[n-1][m-1]
通俗地講,如果一個列表中的元素本身就是一個列表,則這個列表就是一個二維列表。
如:
>>> list1=['a1','b1','c1','d1']
>>> list2=['a2','b2','c2','d2']
>>> list3=['a3','b3','c3','d3']
>>> listtwo=[list1,list2,list3]
>>> listtwo
[['a1', 'b1', 'c1', 'd1'], ['a2', 'b2', 'c2', 'd2'], ['a3', 'b3', 'c3', 'd3']]
如果要查看二維列表listtwo按照行、列的排列,可以運行如下代碼:
for i in range(3):
for j in range(4):
print(listtwo[i][j],end=' ')
print()
運行結果:
a1 b1 c1 d1
a2 b2 c2 d2
a3 b3 c3 d3
如果要讀取二維列表中的某一行,可以使用如下方法:
>>> listtwo[2] #讀取第3行的元素(注意索引號都是從0開始的)
['a3', 'b3', 'c3', 'd3']
如果要讀取某一個元素的值,可以使用如下方法:
>>> listtwo[2][2] #讀取第3行第3列的元素
'c3'
⑤ 在做測試自動化時,python中的列表和元組這兩種數據類型有何區別
一、相同點:
1)都是用於存儲一串數據,
2)元素之間都是使用 , 分隔
3)都有索引,且索引都是從 0 開始,都可以通過下標獲取元素。
二、不同點:
1)元組用 () 定義,而列表用[]定義
2)最大區別:元組的 元素不能修改【除非數據是列表和字典】,而列表的元素是可以修改的
3)元祖的元素一般都是不同類型數據,而列表存儲的數據一般是相同類型的數據(列表存儲不同類型的數據,不常用)
4)元素是應用於特定情況(後面會講),而列表卻是應用最多的一種數據類型。我也是在黑馬程序員技術看到的,能學會這么多
⑥ python列表和元組的區別
1、元組是不可變的, 而列表是可變的。
2、元組通常有不同的數據類型,而列表是相同類型的數據隊列。元組表示的是結構,而列表表示的是順序。
3、不能將列表當作字典的key, 而元組可以
4、由於元組支持的操作比列表小, 所以元組會比列表稍稍快上那麼一點。但是如果不是海量數據處理,這點差異基本可以忽略
⑦ python怎麼提取列表中相同的數據
代碼如下:
c=[1,1,1,1,2,2,2,3,3,4,4,4,4,4,5,5,5,]
a=[]
x=[]
foriinrange(0,len(c)):
ifi+1<len(c):
ifc[i]==c[i+1]:
x.append(c[i])
else:
x.append(c[i])
a.append(x)
x=[]
else:
x.append(c[len(c)-1])
a.append(x)
print(a)
運行結果:
⑧ python中,列表在內存中存儲數據,由於列表是沒有長度限制的,所以列表中數據的地址是連續的嗎
.在python中給變數賦值和C語言是完全不同的,在python中變數不是容器,只是個標簽。
在Python中先創建一個字元串對象,然後把引用地址(也就是id() 得到的值)綁定給一個變數名。
不同的程序塊中(在IDLE,python shell中 每一行就算是一個單獨程序塊)即使相同字元串也是單獨創建對象。
在相同程序塊中 相同字元串對象會有緩存機制就是引用同一個字元串對象地址綁給不同變數。
⑨ Python列表的常用操作- 查找方法【詳細講解】
列表的作用是一次性存儲多個數據,程序員可以對這些數據進行的操作有:增、刪、改、查。
下面講解的是對列表的查找操作,可以分為兩種方法,一種是根據下標來進行查找,另外一種是根據查找函數來操作。
回憶一下知識點,之前講過字元串的時候有說到下標,下標是計算機內存分配的從0開始的編號,目的是根據下標可以找到針對性的數據。列表也可以根據下標來找到數據,後面學習的元組同樣也可以。
語法:
注意:如果以後都是用下標來查找數據,語法無非就是:序列名[下標]
快速體驗:
列印結果如圖:
語法:
快速體驗:
執行結果如圖:
注意:
語法:
快速體驗:
注意 :
-- 2. 如果書寫了開始和結束位置的下標,則在這個范圍內查找,存在則返回開始位置的下標,如果查找的數據不存在則返回0;
語法:
注意: len()方法是一個公共的方法,無論是字元串、列表還是元組都可以使用
快速體驗:
以上就是列表的4種查找方法,每個方法有自己的語法和作用,這個知識點屬於 Python基礎教程 范疇,所以學起來還是比較輕松地,大家主要多多練習記住函數以及使用方法即可。