我在这个网站上搜索过类似的问题,但没有找到任何有效的解决方案,因此,我提出了这个问题。我正在编写一个Python 3.4程序,其中有一个函数export,它本质上是将数据附加到文本文件中。该函数进行检查以确保存在合适的文件,如果没有,则创建一个文件,然后获取文件的内容,添加附录,并覆盖文件。Python在for line in file:
处抛出错误。此外,在再次运行此程序时,一旦创建了文本文件,就不会发生此错误。以下是功能:
def export(addendum, user):
filename = user + '.txt'
try:
file = open(filename, 'r')
except OSError:
file = open(filename, 'w')
export(addendum, user)
file_contents = ''
print('What day is it? (1-5)')
day = input()
day = int(day)
if day >= 1 and day <= 5:
for line in file:
file_contents += line
file = open(filename, 'w')
new_file = file_contents + 'n' + addendum
file.write(new_file)
file.close()
else:
print('Invalid weekday number...')
sys.exit()
当文件还不存在时,就会发生这种情况,因为那是在写模式下打开文件的时候。写入模式不可读。
我对这里发生的事情的理解是,当第一次调用时文件不存在时,您的except块会打开一个文件并将其放在那里;然后,由于某种原因,您递归,它会命中此调用的第一个块,并在堆栈的该级别完成;当它返回到下一个级别时,第一次调用将继续,但无论堆栈的其他级别做了什么,文件引用仍处于写入模式。当它到达for line in file
时,它会爆炸。
我建议你大大简化你在这里所做的事情。
def export(addendum, user):
filename = user + '.txt'
try:
with open(filename, 'r') as file:
contents = file.read()
except OSError:
contents = ""
day = input("What day is it (1-5)?")
day = int(day)
if not (1 <= day <= 5):
print("Invalid weekday number...")
sys.exit()
contents += 'n' + addendum
with open(filename, 'w') as file:
file.write(contents)