|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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)
|
|