我对 Python 比较陌生,但在阅读了很多关于使用 readline() 和 readlines() 的帖子后,我似乎无法弄清楚这一点。
quotes = open("quotes.txt", "r")
#Opens the quotes file
quote = quotes.readlines()
#Uses the readlines() method to read each line of text file
lineCount = 0
for line in quote:
lineCount += 1
print("{}".format(line.strip()))
所以,这里我使用的是 readlines() 方法,但问题是,这段代码一次打印每一行。
然后我在代码中尝试了 readline(),但是代码只打印了一行,我不会为此显示代码,因为我没有找到它。
我想打印一行,增加一个计数器并中断。
然后在下一次运行代码时,它会打印下一行并换行。
所以,本质上:
当我第一次运行我的程序时,它会打印:
"Quote 1" - Author
然后,在下一次运行时:
"Quote 2" - Author
任何能帮我解决这个问题的人,将不胜感激。
谢谢!
附加信息:
我从一个旧的播客中汇编了一个引号列表,该列表在quotes.txt 文件中逐行写入,这是针对我目前正在使用 Tweepy 模块开发的 Twitter 机器人。目前,我已经收集了大量报价,因此我目前并不担心程序会循环返回并重新开始,直到我接近那个时间。
谢谢大家的帮助。
答案 0 :(得分:2)
为了知道在下一个脚本执行时读取哪一行,我们需要永久保存这些信息。为此,您可以将行计数器写入文本文件并在启动时读取其内容。
但是,在第一次执行脚本时可能会出现问题:如果之前从未运行过该脚本,则不会保存任何文件。从不存在的文件中读取会引发错误。因此我们try
从SAVE_FILE
读取。如果文件可用,我们使用保存的编号。如果它不可用,我们通过定义 line_number_to_show = 0
来初始化行号。然后我们打开包含引号的文件,遍历行号并查找我们感兴趣的行号。如果找到指定的行,我们将其打印出来。下一步是保存下一个程序执行的行号。
一个非常基本的方法如下所示:
SAVE_FILE = 'line_number.txt'
try:
with open(SAVE_FILE) as save_file:
line_number_to_show = save_file.read().strip()
line_number_to_show = int(line_number_to_show)
except (FileNotFoundError, ValueError) as _:
line_number_to_show = 0
with open("quotes.txt") as quotes_file:
for line_number, line in enumerate(quotes_file):
if line_number == line_number_to_show:
print(line)
with open(SAVE_FILE, 'w') as save_file:
line_number_to_show = line_number_to_show + 1
save_file.write(f'{line_number_to_show}')
重要说明:
SAVE_FILE
读取行号很容易出错,因为我们不执行任何完整性检查或在 try/except 块中捕获可能的错误。生产代码需要采取进一步的对策来处理这些问题。.readlines()
将完整的文件内容读入列表,而不是像我那样读取文件。由于列表存储在内存中并读取完整文件,因此在处理大文件时可能会导致高内存消耗。通过 enumerate()
执行此操作会逐块读取文件,并且是 considered to be more memory efficient。答案 1 :(得分:0)
只需使用:
f = open("quotes.txt","r")
lineCount = 0
for i in range(4):
lineCount+=1
print(f.readline())