3 回答
TA贡献1887条经验 获得超5个赞
如果您输入空字符串,您的代码将崩溃(您将收到 IndexError。)
而且,它不是很Pythonic,而且你有一个未使用的变量。例如,您不需要后面的括号return,并且[-1]可以直接访问字符串的最后一个元素。这是一种写法:
def remove(s):
if s and s[-1] == '!':
return s[:-1]
return s
if s将检查输入字符串是否不同,''以确保输入不是空字符串,然后 if 检查是否'!'在其中。
您也可以str.endswith()像用户鲍里斯指出的那样使用(我之前不知道。)
编辑:如果您需要我删除代码以免有任何剧透,我很乐意这样做,但您的帖子本身包含对模型解决方案的尝试。
TA贡献1815条经验 获得超12个赞
如果您使用空字符串调用函数,您将收到该错误,即:
def remove(s):
length = len(s)
if s[len(s)-1] == '!':
new = slice(0,-1,)
return(s[new])
else:
return(s)
remove("")
结果:
Traceback (most recent call last):
File "/Users/steve/Development/Inlet/inletfetch_if2/test/behave/features/Blah.py", line 9, in <module>
remove("")
File "/Users/steve/Development/Inlet/inletfetch_if2/test/behave/features/Blah.py", line 3, in remove
if s[len(s)-1] == '!':
IndexError: string index out of range
发生这种情况是因为您要求字符串中的最后一个字符,并且由于字符串中没有字符,因此字符串中没有最后一个字符。
添加回答
举报