您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Python序列對象與String類型內(nèi)置方法的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Python序列對象與String類型內(nèi)置方法的示例分析”這篇文章吧。
在Python數(shù)據(jù)結(jié)構篇中介紹了Python的序列類型數(shù)據(jù)結(jié)構,這次繼續(xù)深入的學習序列和String類型對象的內(nèi)建方法。
系統(tǒng)
UbuntuKylin 14.04
軟件
Python 2.7.3
IPython 4.0.0
序列類型,即由整數(shù)進行索引的對象的有序集合。其中又可以分為下面兩類:
可變序列:列表,支持元素的插入、刪除、替換
不可變序列:元組、字符串
序列本質(zhì)上是由索引對象來指向內(nèi)存中的數(shù)據(jù)對象,所以序列數(shù)據(jù)對象都支持迭代方式,也都能夠支持下列幾種操作。
In [1]: li = [1,2,'name'] In [2]: li[0] Out[2]: 1 In [3]: tp = (1,2,'name') In [4]: tp[1] Out[4]: 2 In [6]: str = 'Jmilk' In [7]: str[2] Out[7]: 'i'
sequenceName[x:y] ? 切割出由索引X到y(tǒng)-1之間的元素。
注意:索引均由0開始。而且序列的切片操作會返回一個生成一個新的對象,不會讓原序列發(fā)生改變。
In [12]: li[:3] Out[12]: [1, 2, 'name'] In [13]: li[1:3] Out[13]: [2, 'name'] In [14]: tp[1:3] Out[14]: (2, 'name') In [15]: str[1:3] Out[15]: 'mi'
sequenceName[x:y:stride] ? 除了切割除x到y(tǒng)-1直接的元素,再對這些元素以stride-1的步進(間隔)進行挑選。
擴展切片運算符能夠支持步進。即獲取下一個索引之間的間隔。
In [16]: str = 'My name is Jmilk!' In [21]: str[1:10:2] Out[21]: 'ynm s'
首先切割除第2到10個元素(空格也算一個),再每隔1個元素挑選一個元素。
序列的索引還可以是負數(shù),-1指向序列的最后一個元素,以此類推。Example:
In [30]: str[-1] Out[30]: '!' In [31]: tp[-1] Out[31]: 'name'
還有下面兩種有趣的玩法:
反轉(zhuǎn)序列
In [27]: str Out[27]: 'My name is Jmilk!' In [28]: str[::-1] Out[28]: '!klimJ si eman yM'
倒轉(zhuǎn)刪除元素
In [33]: str[:-2] Out[33]: 'My name is Jmil'
刪除了倒數(shù)第1到第2個元素。
連接操作符' + ‘,可以將若干個同類型的序列對象連接到一起。
In [1]: str = 'My name is ' In [2]: name = 'Jmilk' In [3]: str + name Out[3]: 'My name is Jmilk' In [4]: name = ['Jmilk'] In [5]: str + name --------------------------------------------------------------------------- TypeError Traceback (most recent call last) <ipython-input-5-894081027c0a> in <module>() ----> 1 str + name TypeError: cannot concatenate 'str' and 'list' objects
如果使用連接操作符處理兩個不同類型的序列,會出現(xiàn)類型錯誤。
重復運算符' * ‘,能夠讓被操作數(shù)重復的n次,并生成一個新的同類型序列。
In [16]: star = '*' In [17]: star * 10 Out[17]: '**********' In [18]: star = ['*','*'] In [19]: star * 10 Out[19]: ['*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*', '*']
成員運算符 in\not in 能夠判斷一個指定對象是否是作為一個容器中的元素,由此來判斷兩個對象間的關系。在Python運算符一篇中有詳細的介紹,傳送門:https://www.jb51.net/article/172479.htm
In [333]: li = [1,2,3] In [334]: 1 in li Out[334]: True In [335]: 1 not in li Out[335]: False
注意:建議在學習一個方法之前,先使用help()函數(shù)來查看方法的使用說明文檔,其中參數(shù)類型可能為iterable迭代器。iterable迭代器分為下面3類:
1.所有的序列類型list、str、tuple。
2.非序列類型dict、file。
3.自定義的任何包含__iter__()或__getitem__()方法的類的對象。
即函數(shù)參數(shù)中包含iterable,表示可以傳遞迭代器類型實參。
序列對象的長度,即序列對象元素的個數(shù)
In [39]: name = 'Jmilk' In [40]: len(name) Out[40]: 5
將兩個序列對象索引相同的兩個元素結(jié)合成元組,以較短的程度為準。
In [54]: str Out[54]: ['my', 'name', 'is', 'Jmilk'] In [55]: name Out[55]: 'Jmilk' In [56]: zip(name,str) Out[56]: [('J', 'my'), ('m', 'name'), ('i', 'is'), ('l', 'Jmilk')]
enumerate(sequence[,start = 0])接收一個序列類型的參數(shù),返回由每一對索引號和元素組成的元組??梢灾付ㄋ饕钠鹗嘉恢?。
In [86]: for i,word in enumerate(name,2): print i,word ....: 2 m 3 y 4 5 n 6 a 7 m 8 e 9 10 i 11 s 12 13 j 14 m 15 i 16 l 17 k
sorted(iterable, cmp=None, key=None, reverse=False) –> new sorted list
iterable:待排序的對象
cmp(x,y):指定一個定制的能夠比較兩個接收到的參數(shù)的函數(shù),默認為None,即內(nèi)建的比較函數(shù)。
key(x):指定一個接收一個參數(shù)的函數(shù),用作在每個元素中提取一個關鍵值作為比較值,缺省為None比較每個元素。
reverse:False為默認正序排列,True為逆序排列。
注意:沒有__getitem__屬性的對象,如:int類型是不能調(diào)用key和cmp函數(shù)的。
注意:在Python中有許多內(nèi)建的函數(shù)需要指定一個定制的函數(shù),如:map()、filter()、reduce()、包括sorted等,這種時候使用lambda匿名函數(shù)將會非常的方便。
排序效率:key 、reverse > cmp 。因為cmp函數(shù)進行多次的兩兩比較,而key、reverse對每個輸入記錄只會被調(diào)用一次。
Key函數(shù):以第二個關鍵字為比較值排序
In [205]: li = [('a',3),('b',2),('c',1)] In [208]: sorted(li,key = lambda keyword:keyword[1]) Out[208]: [('c', 1), ('b', 2), ('a', 3)]
cmp函數(shù):以第二個關鍵字為比較值排序
In [213]: sorted(li,cmp = lambda x,y:cmp(x[1],y[1])) Out[213]: [('c', 1), ('b', 2), ('a', 3)]
reverse:逆序排列
In [216]: sorted(li,lambda z,x:cmp(z[1],x[1]),reverse=True) Out[216]: [('a', 3), ('b', 2), ('c', 1)]
In [84]: for word in reversed(name): print word, ....: k l i m j s i e m a n y m
In [43]: min(str) Out[43]: ' ' In [44]: min(li) Out[44]: 1
若元素是String類型的化會轉(zhuǎn)換為ASCII碼計算后再比較。
類似min()方法。
注意:sum()方法不支持元素為String或Char類型的序列。
In [59]: num = [1,2,3,4] In [60]: str = 'My name is Jmilk' In [61]: sum(num) Out[61]: 10 In [62]: sum(str) --------------------------------------------------------------------------- TypeError Traceback (most recent call last) <ipython-input-62-3a5f0824550a> in <module>() ----> 1 sum(str) TypeError: unsupported operand type(s) for +: 'int' and 'str'
會觸發(fā)類型錯誤,不支持的運算數(shù)類型
全True則Truw
In [63]: num = [1,2,3,''] In [64]: all(num) Out[64]: False In [65]: num = [1,2,3,True] In [66]: all(num) Out[66]: True
注意:所以的空值序列對象都是False
有True則True
In [67]: num = [1,2,3,''] In [68]: any(num) Out[68]: True
In [64]: name = u"My name is JMilk" In [65]: name Out[65]: u'My name is JMilk'
下面介紹適用于字符串的內(nèi)建方法。
In [88]: str = 'my name is jmilk' In [89]: str.capitalize() Out[89]: 'My name is jmilk'
lower()、upper() 將字符串都使用小寫、大寫
In [90]: str.lower() Out[90]: 'my name is jmilk' In [91]: str.upper() Out[91]: 'MY NAME IS JMILK'
In [92]: str.title() Out[92]: 'My Name Is Jmilk'
S.index(sub [,start [,end]]) -> int 在start-end的范圍內(nèi)找到substring對應的索引號,再返回一個int類型對象。
In [92]: str.title() Out[92]: 'My Name Is Jmilk' In [93]: str.title().index('J',2,13) Out[93]: 11
當在指定范圍內(nèi)沒有查詢到substring時,會觸發(fā)ValueError: substring not found的錯誤。同時可以看出,String類型對象調(diào)用了其內(nèi)建方法后仍是String類型。
S.join(iterable) -> string 傳遞一個序列參數(shù),會將String對象插入到序列的元素之間。即將序列的元素以String為分隔符連接起來,string對象可以為空。
In [103]: li = ['a','b','c'] In [104]: str Out[104]: 'my name is jmilk' In [105]: str.join(li) Out[105]: 'amy name is jmilkbmy name is jmilkc'
S.replace(old, new[, count]) -> string
將String中的元素替換為指定的新元素,還可以指定替換的數(shù)量。
In [113]: url = 'www.jmilk.com' In [114]: url.replace('jmilk','fan') Out[114]: 'www.fan.com'
S.split([sep [,maxsplit]]) -> list of strings
輸入指定的分割符和分割次數(shù)兩個參數(shù)。
In [117]: url.split('.',2) Out[117]: ['www', 'jmilk', 'com'] In [118]: url = 'www.jmilk.com' In [119]: url.split('.',2) Out[119]: ['www', 'jmilk', 'com'] In [120]: url.split('.',1) Out[120]: ['www', 'jmilk.com']
S.strip([chars]) -> string or unicode
將String兩端的Chars去掉,并不能去掉String中間的subString
In [124]: url.strip('w') Out[124]: '.jmilk.com' In [125]: url.strip('m') Out[125]: 'www.jmilk.co' In [126]: url.strip('om') Out[126]: 'www.jmilk.c'
以上是“Python序列對象與String類型內(nèi)置方法的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。