从python的csv阅读器订阅特定的行?

ahh*_*hhh 8 python csv file-io

我希望能够通过csv阅读器访问csv文件的特定行.例如,第四行.有没有办法用python的csv阅读器模块做到这一点?

jsb*_*eno 4

您只需解析所有 CSV 文件,然后使用正常的排序索引即可。

否则,你可以做这样的事情

def my_filter(csv_file, lines):
   for line_number, line in enumerate(csv_file):
       if line_number in lines:
          yield line

my_file = open("file.csv")
my_reader = csv.reader(my_filter(my_file, (3,)))
Run Code Online (Sandbox Code Playgroud)

请注意,您无法避免以某种方式或另一种方式解析整个文件,因为这些行的长度是可变的。仅当找到“\n”时,行计数才会增加,并且必须逐个字符地查找它。

另外,如果您碰巧在 csv 文件的引号内有换行符,则此过滤器将不起作用 - 可能您最好将整个文件解析为列表,并从那里检索索引,无论如何:

my_file = open("file.csv")
my_reader = csv.reader(my_file)
my_line = list(my_reader)[3]
Run Code Online (Sandbox Code Playgroud)

更新 最重要的是:如果您需要随机访问太大而无法放入内存的信息,只需考虑将其转储到 SQL 数据库即可。它将省去重新发明很多轮子的麻烦。