上節簡單介紹了Python中版本、注釋以及數據類型,本節著重介紹Python中字符串、列表、元組的基本用法和注意事項。
往期目錄
Python基礎知識(一)
補充知識:序列的通用操作
序列的通用操作(str,list,tuple):取值,切片,步長,通用操作即指str,list,tuple都適用的操作。以下以字符串舉例:
#初始化字符串
s = '123456789'
#取值 按索引取值,自左向右從0開始
s[0]
>>>'1'
#切片 給出起始索引和結束索引取出片段,[1:2]前者為起始索引,后者是結束索引
s[1:2]
>>>'23'
#步長 [1:2:3] 3是指步長,在切片內每三個元素為一組取出第一個元素。如果切片內元素個數小于步長,則默認取出切片內全部元素;
s[1:2:3]
>>>'2'
s[::3]
>>>'147'
#注:不設置起始索引和結束索引,默認取所有元素,步長為3,在切片每三組取出第一個元素
#用len()計算序列元素的個數
len(s)
>>>9
一.列表的常用方法
- 創建列表
>>>ls = list()
2.在列表末尾添加單個元素
>>>ls.append('a') #參數是元素對象
>>>ls
['a']
3.在列表末尾添加多個元素
>>>ls.extend([1,2,3]) #類似于 +拼接
>>>ls
['a', 1, 2, 3]
注:ls.extend(obj),obj可以是元素、列表、字典,如是字典則只會添加字典的key 。
4.指定位置插入元素
ls.insert(2,'b') #(索引,元素)
>>>ls
['a',1,'b',2,3]
注:若要插入列表末尾索引用len(ls),如果索引值超出列表,則默認插入到列表末尾,不考慮插入索引越界。
5.取出列表中元素的索引
>>>ls.index('a')
0
>>>ls.index('c')
ValueError: 'c' is not in list
>>>lss = ['a','b','b','b','c']
>>>lss.index('b',2)
2
>>>lss.index('b',1,2)
1
注:如果元素不存在列表中會報錯;如果元素中存在多個相同元素,可以指定從第幾個索引開始取;index('b',2)指從列表中第2個索引開始到結尾這一片段中取出最左邊的一個元素'b'的索引;index('b',1,2)指取出列表從索引1到索引2這一片斷中最左邊的一個元素‘b'的索引,如果取不到元素也報錯。
6.統計某個元素在列表中出現的次數
>>>ls.count('a')
1
>>> ls.count('c')
0
注:如果元素不存在列表中,不報錯,返回值是0
7.出棧,指將指定元素移出列表,可指定位置(索引),默認值是-1,返回值是索引對應的元素
>>>ls.pop()
3
>>>ls
['a',1,'b',2]
>>>ls.pop(0)
'a'
>>>ls
[1,'b',2]
8.移除單個元素
>>>ls.remove('b')
>>>ls
[1,2]
ls = [1,2,1,2,1,2]
ls.remove(1)
>>>ls
[2,1,2,1,2]
注:如果列表中存在多個相同元素,默認移除最左邊開始第一個
9.清空整個列表
>>>ls.remove()
>>>ls
10.復制整個列表
>>>ls1 = [1,2,3,4]
>>>ls2 = ls1.copy()
>>>ls2
[1,2,3,4]
11.反向列表中的元素
>>>ls1.reverse()
>>>ls1
[4,3,2,1]
12.對原列表進行排序,原列表中元素要相同
>>>ls1 = [2,1,3,5,4]
>>>ls1.sort()
>>>ls1
[1,2,3,4,5]
>>>ls2 = ['b','a','c']
>>>ls2.sort()
>>>ls2
['a','b','c']
>>>ls3 = [[1,2,2],(1,),'11232333']
>>>ls3.sort()
TypeError: '<' not supported between instances of 'tuple' and 'list'
>>>ls3.sort(key=len)
>>>ls3
[(1,), [1, 2, 2], '11232333']
>>>ls3.sort(key=len,reverse=True)
>>>ls3
['11232333', [1, 2, 2], (1,)]
注:L.sort(key=None, reverse=False),默認有兩個參數,key會自動根據列表中類型變化(前提是元素類型相同),也可指定根據何種類型排序,key = int / str / len / lambda ,reverse默認為升序;如果元素類型不同需要指定按何種標準排序,且元素都適用這一標準,如ls3
13.內置函數
內置函數會返回一個新的列表對象,而不改變原列表;
排序:sorted(obj,key=None,reverse=False)
反向:reversed(obj)
>>>sorted(ls3,key=len)
[(1,), [1, 2, 2], '11232333']
>>>ls3
['11232333', [1, 2, 2], (1,)]
>>>reversed(ls3)
[(1,), [1, 2, 2], '11232333']
>>>ls3
['11232333', [1, 2, 2], (1,)]
二.元組的常用方法
1.創建元組
>>>tp = ('a','b','a','b','a','b')
注意:聲明只有一個元素的元組時要加逗號,如 tp = ('a',)
2.統計元素在元組中出現的次數
>>>tp.count('a')
3
3.取出元組中元素的索引
>>>tp.index('a')
0
>>>tp.index('a',1)
2
>>>tp.index('a',2,4)
2
>>>tp.index('c')
ValueError: tuple.index(x): x not in tuple
>>>tp.index('a',1,2)
ValueError: tuple.index(x): x not in tuple
注:'a'在元組中有多個,默認取出最左邊的第一個;也可指定取出第幾個'a',自左向右從0開始。如果元素不存在或指定位置的元素不存在,會報錯。
三.字符串的常用操作
1.創建字符串
>>>s = '121212343434'
2.統計子字符串在字符串中出現的次數
>>>s.count('1')
3
>>>s.count('2',2,3)
1
注:在字符串中count方法帶可選參數,可指定在起始索引到結束索引切片中統計次數
3.取出子字符串的索引:S.index(sub[, start[, end]]) -> int
>>>s.index('1')
0
>>>s.index('2',1,3)
1
注:取出子字符串的索引,或取出子字符串在指定切片中的索引,有重復字符默認取出最左邊第一個。取不到則報錯。
4.查找字符的索引:S.find(sub[, start[, end]]) -> int
>>>s.find('1')
0
>>>s.find('2',1,2)
1
注:該方法和index類似,不同的是如果取不到,index報錯;find不報錯,返回-1。
5.字符串替換:S.replace(old, new[, count]) -> str
>>>s.replace('1','x')
'x2x2x2343434'
>>>s.replace('2','y',2)
'1y1y12343434
>>>s
'121212343434'
注:字符串是不可變的,所以替換并沒有改變原有字符串,而是得到了一個新的字符串。s.replace('2','y',2) 2是替換的個數。
6.字符串分割:S.split(sep=None, maxsplit=-1) -> list of strings
>>>s.split()
['121212343434']
>>> s.split('2')
['1', '1', '1', '343434']
>>> s
'121212343434'
>>> s.split('2',2)
['1', '1', '12343434']
注:s.split()返回一系列用空格分割的字符串列表;s.split('2',2)按'2'分割,最多分割2次。
7.字符串判其他操作
#判斷字符串是否以x開頭
s.startswith(x)
#判斷字符串是否以x結尾
s.endswith(x)
#字符串轉小寫
s.lower()
#字符串轉大寫
s.upper()
#測試是否全是小寫
s.islower ()
#測試是否全是大寫
s.isupper ()
#測試是否全是字符,都是返回 True,否則返回 False
s.isalpha ()
#測試是否全是數字,都是返回 True 否則返回 False
s.isdigit ()
新手上路多多指教!錯誤之處敬請指出來!下節介紹集合和字典!