
有一串長的字符串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)統計出最長的名字;(3)統計出同姓人的名單。
解讀題目要求,我們可以這樣考慮。過濾掉名字左右的空格和亂碼,我們可以考慮使用strip函數;每個名字首字母大寫,我們可以用title函數;要統計最長的名字,我們需要將每個名字的字符串個數進行切片統計,這里用split函數。
根據上面的思路,編寫的代碼如下:
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)
輸出的結果是:
[('Zhang San Feng', 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)]
下面介紹剛才使用到的函數。
1.strip函數
用于移除字符串頭尾指定的字符(默認為空格或換行符)或字符序列。但需要注意的是,該方法只能刪除開頭或結尾的字符,不能刪除中間部分的字符。
語法是:str.strip([chars]), chars—移除字符串頭尾指定的字符序列。
返回值:返回移除字符串頭尾指定的字符生成的新字符串。
2.split函數
通過指定分隔符對字符串進行切片,如果參數num有指定值,則分隔num+1個子字符串。
語法:str.split(str=“ ”,num=string.count(str))。str—分隔符,默認為所有的空字符,包括空格、換行、制表符等;num—分割次數,默認為-1,即分隔所有。
最后,給大家介紹一些優秀的python代碼。
1.簡潔的表達式,比如if/else放在一行里面
def test(m):return 'a' if m==1 else 'b'
2.構成一個字典序列
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的數字,若是3的倍數就用apple代替,若是5的倍數就用orange代替,若既是3的倍數又是5的倍數就用appleorange代替。
print(['apple'[i%35::]+'orange'[i%56::] or i for i in range(1,21)])
很多問題一行代碼都可以搞定,但是我覺得作為一個小白,咱們還是老老實實的一步一步的編寫代碼,等到自己有能力的時候,在玩這些騷操作吧。
今天的分享就到這里,我盡可能地把每一個問題都講透徹,希望小伙伴們一定要動手操作,把每個代碼都親手敲一遍。別人的思考應該是你思考的起點,但絕非是你思考的終點。