|  | 
 
| 
代码如下:
x
马上注册,结交更多好友,享用更多功能^_^您需要 登录 才可以下载或查看,没有账号?立即注册  str1 = '''   *********    '''
 list1 = []
 length = len(str1)
 for i in range(length) :
 if str1[i] == '\n':
 continue
 strleft1 = str(str1[i-3:i])
 strleft2 = str(str1[i-4:i])
 strright1 = str(str1[i+1:i+4])
 strright2 = str(str1[i+1:i+5])
 if strleft1.isupper() and not strleft2.isupper():
 if str1[i].islower():
 if strright1.isupper() and not strright2.isupper():
 list1.append(str1[i])
 print(list1)
 
 
 
 这样写又什么问题吗
 
hypomania 发表于 2021-6-7 10:59运行结果为:['u', 'i', 'l', 'o', 'v', 'e', 'f', 'i', 's', 'd', 'h', 'c']
 多出了一个  u   和   d
多出这些字符的原因是在字符判断中将 \n 字符也加入判断了
 
 虽然你代码中判断遇到 \n 就重新循环,但是实际上在判断 小写字符前后,\n 还是属于会被算入前或后三个字符中去的
 
 所以你需要先将 str1 中的换行符给替换,即: str1.replace('\n','')
 
 参考代码:
 
 
 复制代码str1 = ''' ******* '''
list1 = []
length = len(str1)
str1 = str1.replace('\n','')
for i in range(length) :
    strleft1 = str(str1[i-3:i])
    strleft2 = str(str1[i-4:i])
    strright1 = str(str1[i+1:i+4])
    strright2 = str(str1[i+1:i+5])
    if strleft1.isupper() and not strleft2.isupper():
        if str1[i].islower():
            if strright1.isupper() and not strright2.isupper():
                list1.append(str1[i])
print(list1)
 
 | 
 |