事情起因是偶然用到strip()函数
str="goodprogrammer"
print(str.strip('good'))
print(str.strip('odg'))
运行结果二者的结果居然相同,当时就感觉很不理解
书上的解释是:
strip(【chars】) :删除字符串头尾指定的 chars 字符,默认删除空白字符
但这个解释比较笼统不是很能理解,后来在查阅资料后有了些自己的理解,希望能对大家有所帮助
字符串【chars】在使用strip()的时候,只有在第一个字符被删掉之后,再去匹配后边的字符,而第一个出现的不在参数chars中字符即为中间和头尾的边界,中间部分即使包含chars中的字符也不会被删除。
str.strip('odg')在使用时先检索str中第一个字符,即在字符串【chars】中开始检索,不区分顺序,第一个是g,在【chars】中存在则匹配,再检索第二个o,依然存在于是删除,一直到出现第一个不在参数chars中的字符p,此时开始判定为中间部分的开始,再从后检索r在【chars】中不存在,则p到结尾r的位置都被判定为中间,中间部分不删除。
str.lstrip()和str.rstrip()就好理解了
str.lstrip()是从左边第一位开始进行检索,有则删除,如果第一位未删除,即使后边匹配,仍然无效。
str.rstrip()是从右边第一位开始进行检索,有则删除,如果第一位未删除,即使后边匹配,仍然无效。
eg:
str="goodprodghnjhgggggoodmergoddog"
print(str.lstrip('odg'))
print(str.rstrip('good'))
运行结果:
如果全部检索完都未达到中间的判定条件则相当于全部匹配,全部删除
eg:
str="goodprodghnjhgggggoodmergoddog"
print(str.lstrip('godprhnjme'))
运行结果:
最后还有一个比较有意思的题,乍一看感觉很难,但在理解这个函数原理后就会非常简单
给定任意一个字符串数组 words,只返回可以使用在美式键盘同一行的字母打印出来的单词,键盘布局如下图所示。
美式键盘中:
第一行由字符 “qwertyuiop” 组成
第二行由字符 “asdfghjkl” 组成
第三行由字符 “zxcvbnm” 组成
举例:
输入:words = [“Twitter”, “TOTO”, “FishC”, “Python”, “ASL”])
输出:[‘Twitter’, ‘TOTO’, ‘ASL’]
答案:
words = ["Twitter", "TOTO", "FishC", "Python", "ASL"]
list1 = []
for i in words:
j = i.lower()
if j.strip("qwertyuiop") == '' or j.strip("asdfghjkl") == '' or j.strip("zxcvbnm") == '':
list1.append(i)
print(list1)
运行结果: