如何使用 Python 3.5 .seek() .txt 文件的结尾

Aan*_*nth 7 python logging python-3.x

我正在制作一个程序,用于记录用户在用户友好的日志文件中所做的事情,该文件存储为 .txt。到目前为止,它只记录会话的开始和结束,这是完全相同的时间。但是,目前当我运行该程序时,它会删除文件的先前内容。我相信这是由于光标试图指向 (0, 0)。有没有办法到达文件的末尾?代码如下。


import atexit
import datetime

def logSession():
    sessionRecord = open(r'C:\Users\Aanand Kainth\Desktop\Python Files\Login Program\SessionRecords.txt', "r+")

     sessionRecord.seek(-1,-1)

     sessionRecord.write("Session Began: " '{:%Y-%m-%d | %H:%M:%S}'.format(datetime.datetime.now()) + "\n")

 def runOnQuit():
     sessionRecord = open(r'C:\Users\Aanand Kainth\Desktop\Python Files\Login Program\SessionRecords.txt', "r+")

     sessionRecord.seek(-1,-1)

     sessionRecord.write("Session Ended: " '{:%Y-%m-%d | %H:%M:%S}'.format(datetime.datetime.now()) + """\n-------------------------------------------------------------------------------------------\n""")

 logSession()

 atexit.register(runOnQuit)
Run Code Online (Sandbox Code Playgroud)

如果您在计算机上创建必要的文件,并运行此 .PY 文件,您会发现有时它可以正常工作,而其他时候却没有。谁能告诉我如何寻求到底,或者是否有更好的解决方案来帮助我?这是一个自我分配的挑战,所以我不喜欢赠品,只是提示。

ACh*_*ion 17

您的参数seek不正确,seek需要 2 个参数,一个偏移量(多少字节)和描述从哪里寻找的位置(开始:0,当前:1,结束:2)。所以你需要的是:

import io
sessionRecord.seek(0, io.SEEK_END)
Run Code Online (Sandbox Code Playgroud)

或者:

sessionRecord.seek(0, 2)   # Py2
Run Code Online (Sandbox Code Playgroud)

但是您可以通过以追加模式打开文件来避免这样做:

with open('<filename>', 'a'):
    sessionRecord.write(...)
Run Code Online (Sandbox Code Playgroud)


Tig*_*kT3 8

只需以正确的模式打开文件。如果您想添加到文件而不删除其先前的内容,请使用'a'(for "append") 而不是'r+',这是一个截断的读/写。然后您将不再需要使用seek().