Python內建型別及其用法

2021-08-14 18:09:17 字數 3920 閱讀 1648

1、list:列表 (即動態陣列,c++標準庫的vector,但可含不同型別的元素於乙個list中)

**如下:

a = ["i","you","he","she"]      #元素可為任何型別。
下標:按下標讀寫,就當作陣列處理

以0開始,有負下標的使用

0第乙個元素,-1最後乙個元素,

-len第乙個元 素,len-1最後乙個元素

取list的元素數量

複製** **如下:

len(list) #list的長度。實際該方法是呼叫了此物件的len(self)方法。

建立連續的list

**如下:

l = range(1,5)      #即 l=[1,2,3,4],不含最後乙個元素

l = range(1, 10, 2) #即 l=[1, 3, 5, 7, 9]

list的方法

**如下:

l.insert(index,var)

l.pop(var) #返回最後乙個元素,並從list中刪除之

l.remove(var) #刪除第一次出現的該元素

l.count(var) #該元素在列表中出現的個數

l.index(var) #該元素的位置,無則拋異常

l.extend(list) #追加list,即合併list到l上

l.sort() #排序

l.reverse() #倒序

list 操作符:,+,*,關鍵字del

**如下:

a[1:]       #片段操作符,用於子list的提取

[1,2]+[3,4] #為[1,2,3,4]。同extend()

[2]*4

#為[2,2,2,2]

del l[1] #刪除指定下標的元素

del l[1:3] #刪除指定下標範圍的元素

list的複製

**如下:

l1 = l      #l1為l的別名,用c來說就是指標位址相同,對l1操作即對l操作。函式引數就是這樣傳遞的

l1 = l[:] #l1為l的轉殖,即另乙個拷貝。

2、dictionary: 字典(即c++標準庫的map)

**如下:

dict =
每乙個元素是pair,包含key、value兩部分。key是integer或string型別,value 是任意型別。

鍵是唯一的,字典只認最後乙個賦的鍵值。

dictionary的方法

**如下:

d.get(key, 0)       #同dict[key],多了個沒有則返回預設值,0。沒有則拋異常

d.has_key(key) #有該鍵返回true,否則false

d.keys() #返回字典鍵的列表

d.values()

d.items()

d.update(dict2) #增加合併字典

d.popitem() #得到乙個pair,並從字典中刪除它。已空則拋異常

d.clear() #清空字典,同del dict

d.copy() #拷貝字典

d.cmp(dict1,dict2) #比較字典,(優先順序為元素個數、鍵大小、鍵值大小)

#第乙個大返回1,小返回-1,一樣返回0

dictionary的複製

**如下:

dict1 = dict        #別名

dict2=dict.copy() #轉殖,即另乙個拷貝。

3、tuple:元組(即常量陣列)

**如下:

tuple = ('a', 'b', 'c', 'd', 'e')
可以用list的 ,:操作符提取元素。就是不能直接修改元素。

4、string: 字串(即不能修改的字元list)

**如下:

str = "hello my friend"
字串是乙個整 體。如果你想直接修改字串的某一部分,是不可能的。但我們能夠讀出字串的某一部分。

子字串的提取

**如下:

str[:6]
字串包含 判斷操作符:in,not in

**如下:

"he"

in str

"she"

notin str

string模組,還提供了很多方法,如

**如下:

s.find(substring, [start [,end]]) #可指範圍查詢子串,返回索引值,否則返回-1

s.rfind(substring,[start [,end]]) #反向查詢

s.index(substring,[start [,end]]) #同find,只是找不到產生valueerror異常

s.rindex(substring,[start [,end]])#同上反向查詢

s.count(substring,[start [,end]]) #返回找到子串的個數

s.lowercase()

s.capitalize() #首字母大寫

s.lower() #轉小寫

s.upper() #轉大寫

s.swapcase() #大小寫互換

s.split(str, ' ') #將string轉list,以空格切分

s.join(list, ' ') #將list轉string,以空格連線

處理字串的內建函式

**如下:

len(str)                #串長度

cmp("my friend", str) #字串比較。第乙個大,返回1

max('abcxyz') #尋找字串中最大的字元

min('abcxyz') #尋找字串中最小的字元

string的轉換

oat(str) #變成浮點數,float("1e-1″) 結果為0.1

int(str) #變成整型, int("12″) 結果為12

int(str,base) #變成base進製整型數,int("11″,2) 結果為2

long(str) #變成長整型,

long(str,base) #變成base進製長整型,

字串的格式化(注意其轉義字元,大多如c語言的,略)

**如下:

str_format % (引數列表)  #引數列表是以tuple的形式定義的,即不可執行中改變

>>>print

""%s's height is %dcm" % ("my brother", 180)

#結果顯示為 my brother's height is

180cm

list 和 tuple 的相互轉化

**如下:

tuple(ls)

list(ls)

python 去掉list中重複的元素

**如下:

a = [3, 3, 5, 7, 7, 5, 4, 2]

a = list(set(a)) # [2, 3, 4, 5, 7] 連排序都做好了

python內建型別 python列表內建型別方法

列表操作方法 對列表l操作 例如list range 1,5 即 list 1,2,3,4 不含最後乙個元素 list range 1,10,2 即 list 1,3,5,7,9 在列表末尾新增新的物件 2 list.count obj 統計某個元素在列表 現的次數 3 list.extend se...

python內建型別

元組 不可變,所以是可雜湊的 列表 實質上可被認為是長度可變的陣列 cpython 是由對其他物件的引用組成的連續陣列。指向這個陣列的指標及長度被儲存在列表的頭結構中。但是,python在建立列表的時候會採用指數過分配,使得新增或取出元素的平坦複雜度小。列表推導式 解析器在對列表推導求值的時候並不知...

python內建型別

python直譯器中主要內建型別有數字 序列 對映 類 例項和異常。有三種基本序列型別 list,tuple和range 通用序列操作 大多數序列型別,包括可變型別和不可變型別都支援下表中的操作。此表按優先順序公升序列出了序列操作,在 中,s和t是具有相同型別的序列。n i j和k是整數而x是任何滿...