有一串長的字符串names = "LI XIA , ZHAO MING ,LAO WANG *,DA XIONG >,LI MEI
MEI, CHANG JIANG,LI QIANG,ZHANG WU JI,ZHANG SAN FENG,DU GU QIU BAI,QIAO
FENG"析校。
要求:(1)過濾所有的名字悦昵,去掉每個名字左右的空格和亂碼杀赢,每個名字的首字母大小比如‘LAO WANG*’椭更,處理成‘Lao wang’肉微;(2)統(tǒng)計出最長的名字杈抢;(3)統(tǒng)計出同姓人的名單印叁。
解讀題目要求曹仗,我們可以這樣考慮榨汤。過濾掉名字左右的空格和亂碼,我們可以考慮使用strip函數(shù)怎茫;每個名字首字母大寫收壕,我們可以用title函數(shù);要統(tǒng)計最長的名字轨蛤,我們需要將每個名字的字符串個數(shù)進行切片統(tǒng)計蜜宪,這里用split函數(shù)。
根據(jù)上面的思路祥山,編寫的代碼如下:
names = "LI XIA , ZHAO MING ,LAO WANG *,DA XIONG >,LI MEI MEI,"\
"CHANG JIANG,LI QIANG,ZHANG WU JI,ZHANG SAN FENG,"\
"DU GU QIU BAI,QIAO FENG"
def problems7(names):
? ? ? ?newnames =[name.title().strip('*>') for name in names.split(',')]
? ? ? ?names_dict= {name:len(name) for name in newnames}
? ? ? ?result= sorted(names_dict.items(),key=lambda x:x[1],reverse=True)
? ? ? print(result)
problems7(names)
輸出的結(jié)果是:
[('Zhang SanFeng', 14), ('Du Gu Qiu Bai', 13), (' Zhao Ming ', 11), ('Chang Jiang', 11),('Zhang Wu Ji', 11), ('Li Mei Mei', 10), ('Lao Wang ', 9), ('Da Xiong ', 9),('Qiao Feng', 9), ('Li Qiang', 8), ('Li Xia ', 7)]
下面介紹剛才使用到的函數(shù)圃验。
1.strip函數(shù)
用于移除字符串頭尾指定的字符(默認為空格或換行符)或字符序列。但需要注意的是缝呕,該方法只能刪除開頭或結(jié)尾的字符澳窑,不能刪除中間部分的字符。
語法是:str.strip([chars]), chars—移除字符串頭尾指定的字符序列供常。
返回值:返回移除字符串頭尾指定的字符生成的新字符串摊聋。
2.split函數(shù)
通過指定分隔符對字符串進行切片,如果參數(shù)num有指定值栈暇,則分隔num+1個子字符串麻裁。
語法:str.split(str=“ ”,num=string.count(str))源祈。str—分隔符煎源,默認為所有的空字符,包括空格新博、換行薪夕、制表符等;num—分割次數(shù)赫悄,默認為-1原献,即分隔所有馏慨。
最后,給大家介紹一些優(yōu)秀的python代碼姑隅。
1.簡潔的表達式写隶,比如if/else放在一行里面
def test(m):return 'a' if m==1 else 'b'
2.構(gòu)成一個字典序列
print(dict(zip('abcd',range(4))))??? >>{'a':0, 'c':2, 'b':1,'d':3}
3.if else print一行搞定
print('ok' if a==1 else 'ko')
4.一行代碼,巧妙的求解:列出1到20的數(shù)字讲仰,若是3的倍數(shù)就用apple代替慕趴,若是5的倍數(shù)就用orange代替,若既是3的倍數(shù)又是5的倍數(shù)就用appleorange代替鄙陡。
print(['apple'[i%35::]+'orange'[i%56::] or i for i in range(1,21)])
很多問題一行代碼都可以搞定冕房,但是我覺得作為一個小白,咱們還是老老實實的一步一步的編寫代碼趁矾,等到自己有能力的時候耙册,在玩這些騷操作吧。
今天的分享就到這里毫捣,我盡可能地把每一個問題都講透徹详拙,希望小伙伴們一定要動手操作,把每個代碼都親手敲一遍蔓同。別人的思考應(yīng)該是你思考的起點饶辙,但絕非是你思考的終點。