導航:首頁 > 編程語言 > python元組分組聚合

python元組分組聚合

發布時間:2023-06-16 16:03:41

1. python中的基本數據類型之元組類型

元組數據類型也是序列類型,和列表類型十分的相似,同樣可以根據索引來獲取元素,並且一樣可以使用切片操作,和列表的不同之處在於,元組是 不可變類型 ,一旦創建是無法修改裡面的值的。

元組是用小括弧表示,數據項與數據項之間用逗號隔開,並且對於元組中數據的類型是沒有限制的

值得注意的是當元組中只有一個元素的時候,我們必須在末尾加逗號

之前講了列表和字元串,都可以通過索引的方式去訪問,元組也一樣,因為三者都是序列類型,訪問的方式和列表、字元串的方式一樣,這里就不在闡述了

元組的內置函數較少,並且十分簡單

1.max、min最大值和最小值函數

2.tuple將 序列類型 轉換成元組類型

以上內容是元組中的主要內容,後面當我們用到的時候我們再做其他的解釋

2. python(9):元組

元組是用逗號和圓括弧定義的一種特殊的序列類型,之所以說它是特殊的,是因為它一旦定義之後,不能修改元素,不能添加元素,也不能刪除元素,即它是不可變序列。元組一般有以下兩種定義方法:

元組與列表的異同:

都屬於序列類型,列表是可變序列類型,可隨時修改、添加或刪除元素,元組是不可變序列,其中的元素不可修改。

元組比列表的訪問和處理速度更快,所以如果只需要對其中的元素進行訪問,建議使用元組。

3. Python中元組常用的方法有哪些,分別有什麼作用

元組特點:定義元組使用小括弧,且逗號隔開各個數據,數據可以是不同的數據類型
如果定義的元組只有一個數據也需要加逗號,否則數據類型為唯一的這個數據的數據類型
元組中的數據是不可以刪除,修改的
如果要存儲對個數據,但這些數據是不能修改的數據就使用元組

使用方法:
1、查找 元組數據不支持修改,只支持查找

按下標查找數據
index()
count()
len()

# 1,按下標查找數據
tuplel = ('aa','bb','cc','dd')
print(tuplel[0]) # aa

# 2,index():查找某個數據,如果數據存在返回對應的下標,否則報錯,語法和列表,字元串的index方法相同
tuplel = ('aa','bb','cc','bb')
print(tuplel.index('aa')) # 0

# 3,count():統計某個數據在當前元組中出現的次數
tuplel = ('aa','bb','cc','bb')
print(tuplel.count('bb')) # 2

# 4,len()
print(len(tuplel)) # 4--tuplel 中有4個數據
2、修改

元組內的直接數據如果修改則立即報錯
但是如果元組裡面有列表,修改列表裡面的數據則是支持的,

t1 = ('aa','bb','cc','dd')
# t1[0] = 'aaa' # 直接報錯,列表數據不允許修改

t2 = ('aa','bb',['cc','dd'])
print(t2)
print(t2[2][0])
t2[2][0] = 'xiaoguai'
print(t2)

4. Python中的元組如何應用

元組是不可變的,即元組的項不能被修改。元組用圓括弧「()」括起來,並用逗號「,」來分隔其中的項。

例如,下面的元組包含了三個不同數據類型的項:

關於Python的基礎問題可以看下這個網頁的視頻教程,網頁鏈接,希望我的回答能幫到你。

5. 深入理解python列表和元組

列表和元組都是一個可以放置任意數據類型的有序集合。這里需要注意三個詞,任意、有序、集合,其實就是說明列表和元組是可以放置任意數據類型,其次是有序的,另外,它是一個集合。

列表是動態的,它的長度大小不固定的,可以隨意的增加、刪除或者改變。

元組是靜態的,它的長度大小是固定的,無法增加、刪除或者改變。

列表是動態的、可變的,而元組是靜態的、不可變的。

列表的存儲方式,如下所示:

元組的存儲方式,如下所示:

存儲同樣的元素,元組使用的存儲空間更小,要少16個位元組。這是因為列表是動態的,所以列表中要存儲指針,來指向對應的元素。另外,列表是可變的,所以需要額外存儲已經分配的存儲信息,因為它要知道現在已經存儲了多少信息,還剩下多少,需不需要額外分配存儲空間等等。所以,列表多出來的存儲空間主要是:指針 + 存儲空間長度。

如下例子可以看到列表存儲空間的變化:

列表存儲空間變化:

從列表和元組的存儲方式可以得出,元組的性能是優於列表的。

元組和列表的初始化性能比較:

6. python 元組

L=({'trorNumber':u'1501637780956'},{'trorNumber':u'1506504400409'})
L2=list(map(lambdax:x['trorNumber'],L))
L3=[x['trorNumber']forxinL]

forobjinL:
printobj['trorNumber']
printL2
printL31501637780956
1506504400409
[u'1501637780956',u'1506504400409']
[u'1501637780956',u'1506504400409']

7. Python列表,元組,集合,字典的區別和相互

元組和列表是類似的, 只是元組不可修改內容

注意這里指的是不可修改元組元素的指向, 你可以修改內容指向的內容

>>>lst=[1,2,3]#定義列表
>>>a=(1,2,lst,4)#注意元組a的a[2]是一個列表
>>>a
(1,2,[1,2,3],4)
>>>a[2]=4#試圖修改元組元素的指向,報錯
Traceback(mostrecentcalllast):
File"<pyshell#3>",line1,in<mole>
a[2]=4
TypeError:'tuple'
>>>a[2][0]=0#不修改元組元素的指向的元素,但是修改指向的內容
>>>a
(1,2,[0,2,3],4)
>>>a[2].append(5)#不修改元組元素的指向的元素,但是修改指向的內容
>>>a
(1,2,[0,2,3,5],4)

字典完全區別於列表和元組

因為字典使用hash表來存儲, 所以只有能夠進行hash運算的才能作為鍵值

個人認為, 一般不可變的都能作為鍵, 比如str/tuple/None/function.列表不能作為鍵

最後, 由於字典是hash表演算法{字典查找O(1), 列表遍歷O(n)}, 在數據量巨大的時候, 字典的查找效率出奇的高

8. 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元組分組聚合相關的資料

熱點內容
書本文件夾夾子怎麼安 瀏覽:801
如何更改編譯器的背景 瀏覽:84
linuxcp拷貝文件 瀏覽:608
我的世界如何屏蔽別人伺服器 瀏覽:907
單片機燒錄員 瀏覽:970
美國數據伺服器可以部署什麼業務 瀏覽:973
如何卸載伺服器中的ie 瀏覽:42
單片機必須學編程嗎 瀏覽:153
如何判斷是否與伺服器連接資料庫 瀏覽:740
吃甜食會緩解壓力嘛 瀏覽:317
pdf魔鬼 瀏覽:29
二維數組遞歸解決演算法問題 瀏覽:382
java反射例子 瀏覽:670
惠普筆記本自帶解壓軟體 瀏覽:840
抖音視頻後台壓縮 瀏覽:707
app里的視頻廣告從哪裡接的 瀏覽:556
天翼雲伺服器跟騰訊雲 瀏覽:618
cyk演算法實現 瀏覽:191
大潘號app在哪裡可以下載 瀏覽:109
怎麼做解壓豌豆捏捏樂 瀏覽:618