1. 程式人生 > >Python 內建型別及其用法

Python 內建型別及其用法

本文講述了Python內建型別。記錄以供學習。具體如下:

python內建型別

1、list:列表 (即動態陣列,C++標準庫的vector,但可含不同型別的元素於一個list中)
程式碼如下:

a = ["I","you","he","she"]      #元素可為任何型別。1

下標:按下標讀寫,就當作陣列處理
以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]12

list的方法
程式碼如下:

L.append(var)   #追加元素
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() #倒序123456789

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]  #刪除指定下標範圍的元素12345

list的複製
程式碼如下:

L1 = L      #L1為L的別名,用C來說就是指標地址相同,對L1操作即對L操作。函式引數就是這樣傳遞的
L1 = L[:] #L1為L的克隆,即另一個拷貝。12

2、dictionary: 字典(即C++標準庫的map)
程式碼如下:

dict = {'ob1′:'computer', 'ob2′:'mouse', 'ob3′:'printer'}1

每一個元素是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,一樣返回01234567891011

dictionary的複製
程式碼如下:

dict1 = dict        #別名
dict2=dict.copy()   #克隆,即另一個拷貝。12

3、tuple:元組(即常量陣列)
程式碼如下:

tuple = ('a', 'b', 'c', 'd', 'e')1

可以用list的 [],:操作符提取元素。就是不能直接修改元素。
4、string: 字串(即不能修改的字元list)
程式碼如下:

str = "Hello My friend"1

字串是一個整 體。如果你想直接修改字串的某一部分,是不可能的。但我們能夠讀出字串的某一部分。
子字串的提取
程式碼如下:

str[:6]1

字串包含 判斷操作符:in,not in
程式碼如下:

"He" in str
"she" not in str12

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,以空格連線123456789101112

處理字串的內建函式
程式碼如下:

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進位制長整型,12345678910

字串的格式化(注意其轉義字元,大多如C語言的,略)
程式碼如下:

str_format % (引數列表)  #引數列表是以tuple的形式定義的,即不可執行中改變
>>>print ""%s's height is %dcm" % ("My brother", 180)
#結果顯示為 My brother's height is 180cm123

list 和 tuple 的相互轉化
程式碼如下:

tuple(ls)
list(ls)12

Python 去掉List中重複的元素
程式碼如下:

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