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)