使用DictReader计数

Gli*_*ezz 1 python dictionary count

对于Python来说还是新手,这是我设法得到的:

import csv
import sys
import os.path

#VARIABLES


reader = None
col_header = None
total_rows = None
rows = None

#METHODS


def read_csv(csv_file):
#Read and display CSV file w/ HEADERS
    global reader, col_header, total_rows, rows

#Open assign dictionaries to reader
    with open(csv_file, newline='') as csv_file:
        #restval = blank columns = - /// restkey = extra columns +
        reader = csv.DictReader(csv_file, fieldnames=None, restkey='+', restval='-', delimiter=',',
                                quotechar='"')

        try:
            col_header = reader.fieldnames
            print('The headers: ' + str(reader.fieldnames))
            for row in reader:
                print(row)

            #Calculate number of rows
            rows = list(reader)
            total_rows = len(rows)
        except csv.Error as e:
            sys.exit('file {}, line {}: {}'.format(csv_file, reader.line_num, e))


def calc_total_rows():
    print('\nTotal number of rows: ' + str(total_rows))
Run Code Online (Sandbox Code Playgroud)

我的问题是,当我尝试计算行数时,它会变为0(不可能,因为csv_file包含4行并且它们在屏幕上打印.我已将'#Calculate行数'代码放在我的打印行上方循环,它的工作原理,然后行不打印.就好像每个任务都是相互窃取字典?我该如何解决?

小智 6

问题是该reader对象在迭代CSV时表现得像一个文件.首先,您在for循环中迭代,并打印每一行.然后你尝试从剩下的东西创建一个列表 - 当你遍历整个文件时,它现在是空的.此空列表的长度为0.

试试这个:

rows = list(reader)
for row in rows:
    print(row)

total_rows = len(rows)
Run Code Online (Sandbox Code Playgroud)