我有以下代码是教程的一部分
import csv as csv import numpy as np csv_file_object = csv.reader(open("train.csv",'rb')) header = csv_file_object.next() data = [] for row in csv_file_object: data.append(row) data = np.array(data)
代码的工作原理是应该的,但我不清楚为什么在变量头文件中调用.next()可以工作.是不是csv_file_object仍然是整个文件?当csv_file_object中的行被调用时,程序知道如何跳过标题行,因为它不会出现变量头被定义后被引用?
解决方法
@H_301_9@ 作为调用next()的结果,标题行被“跳过”.这就是迭代器的工作原理.当循环遍历迭代器时,它的next()方法每次被调用.每个调用使迭代器进行.当for循环开始时,迭代器已经在第二行,它从那里开始.
这是the documentation在next()方法(here’s another piece).
重要的是,csv.reader对象是迭代器,就像open()返回的文件对象一样.您可以对它们进行迭代,但是在任何给定的时刻它们都不包含所有行(或任何行).