我想尽可能长时间不要在这里张贴愚蠢的问题,但我不太确定如何自己解决这个问题。我试图读取文件中的特定行(行号根本不改变),但我得到了错误。我可以通过迭代来打印文件中的每一行,但是读取我自己需要的特定行(或除第0行以外的任何一行)会抛出错误,尽管它在以前的版本中有效(最近的更改只是将我需要的行向下移动1,我根据需要调整了行号)。
此错误发生在函数的此区域:
with open("wallet.txt","r") as file:
rawcurrency = file.readlines()[0]
linesplit = rawcurrency.split(": ")
currency = linesplit[1]
rawbalance = file.readlines()[3]
linesplit = rawbalance.split(": ")
global balance
balance = linesplit[1]这一行抛出错误:
rawbalance = file.readlines()[3]
我从外观中读取的文件是这样的:
Currency used: £
Creation Date: 20/05/2020 19:28:31
Starting Wallet Amount = 500.0
Balance: 500.0如果解决办法很简单,我事先很抱歉。
发布于 2020-05-20 18:57:27
正如DYZ所指出的,你读了两遍。无论如何,一个更简单、更直接的解决方案:
import linecache
...
raw_currency = linecache.getline("wallet.txt", 1) # Get line 1
raw_balance = linecache.getline("wallet.txt", 4) # Get line 4
...发布于 2020-05-20 18:49:17
问题是函数readlines()读取整个文件并返回文件中行的列表。你给它打的第一个电话,
file.readlines()[0]
因为它读取整个文件并访问列表的第一个索引,因此它适合您,这是您实际需要的行。你给它打的第二个电话,
file.readlines()[3]
抛出一个异常,因为它从上一次调用(即文件结束)中到达的位置读取整个文件,这意味着它返回一个空列表,因为没有更多的行要读取。然后尝试访问列表中的第三个索引,该索引不存在,因此出现异常。
https://stackoverflow.com/questions/61920540
复制相似问题