我得到IndexError:字符串索引超出范围。文件“document_words”中的每一行以“-99”结尾。所以我认为错误可能是因为“-99”没有转换为int。但我不确定。如果是这种情况我怎么能将“-99”转换为int并从循环中断开。
以下是我的代码:
words=open('words','r')
image=open('document_words','r')
data=open('input','a')
linecount=0
for line in image:
if line.strip():
linecount+=1
image.read()
image.seek(0,0)
while linecount>0:
line1=image.readline().split()
for entry in line1:
num=int(entry)
if (num<0):
print("break from loop")
break
else:
tag=words.readline()[num]
data.write(str(tag)+' ')
data.write('\n')
linecount=linecount-1
data.flush()
data.close()
words.close()
image.close()
答案 0 :(得分:1)
你没有告诉我们哪一行失败了,但这看起来很明显
tag = words.readline()[num]
所以num
超出范围。我不认为它是-99
,因为它应该在这种情况下破坏。您可以添加try / except来帮助跟踪它
try:
tmp = words.readline()
tag = tmp[num]
except IndexError, e:
print tmp, num
编辑:看起来您正在为缩进混合标签和空格。除非您使用8个字符制表符
,否则这是禁止的