找字符串的密码。密码要求如下:
1.密码为1个小写字母
2.密码左右2边有且只有3个大写字母
题目要求找到密码,然后str1的内容是另外的文本里面提供的,很长的一段,下文中的只是举个例子。
str1 = """ABCaABCbABC1"""
countA = 0 # 统计前边的大写字母 #
这3个变量一开始没明白,后来理解了是作为计数器。
countB = 0 # 统计小写字母
countC = 0 # 统计后边的大写字母
length = len(str1)
for i in range(length): #如果遇到当前字符是换行符,则跳过,继续下面的语句
if str1[i] == '\n':
continue
"""
|如果str1[i]是大写字母:
|-- 如果已经出现小写字母:
|-- -- 统计后边的大写字母
|-- 如果未出现小写字母:
|-- -- 清空后边大写字母的统计
|-- -- 统计前边的大写字母
"""
if str1[i].isupper(): #
如果当前字符是大写字母
if countB: #并且,前面一个字符已经是小写了。countB=0是初始的,所以在第一次运行的时候,必定是执行下面else的语句。
#这里要记住,countB=0是False ,这句if语句的意思是,当if countB是True的时候,countC+=1,也就是后面大写字母计数+1.
countC += 1
else:
countC = 0 #如果前面没有找到过小写字母,则countA加1,也就是密码前面大写字母计数加1.
countA += 1
"""
|如果str1[i]是小写字母:
|-- 如果小写字母前边不是三个大写字母(不符合条件):
|-- -- 清空所有记录,重新统计
|-- 如果小写字母前边是三个大写字母(符合条件):
|-- -- 如果已经存在小写字母:
|-- -- -- 清空所有记录,重新统计(出现两个小写字母)
|-- -- 如果该小写字母是唯一的:
|-- -- -- countB记录出现小写字母,准备开始统计countC
"""
if str1[i].islower():
if countA != 3: #在当前字符是小写的情况下,如果前面大写字母的计数不是3,则清零重新开始
countA = 0
countB = 0
countC = 0
else: #不然,进行下面判断
if countB: #如果已经找到小写字母了,
也就是前面一个也是小写字母,等于是现在出现2个小写字母,则清零重新开始计数
countA = 0
countB = 0
countC = 0
else: #如果不是,则将当前这个字符计数加1
countB = 1 #
表示找到一个小写字母
countC = 0 #
并且C清零,但是我觉得这句没必要?因为你如果前面3个大写字母计数是3的情况下,后面的C总归是0的??
target = i
"""
|如果前边和后边都是三个大写字母:
|-- 如果后边第四个字母也是大写字母(不符合条件):
|-- -- 清空所有记录,重新统计
|-- 如果后边仅有三个大写字母(符合所有条件):
|-- -- 打印结果,并清空所有记录,进入下一轮统计
"""
if countA == 3 and countC == 3:
if i+1 != length and str1[i+1].isupper(): #记住,这里的
i+1!=length的意思是:当前位置不是最后一位!!
countA = 0
countB = 0
countC = 0
else:
print(str1[target], end='')
countA = 3
countB = 0
countC = 0