我有一个使用生成器编写csv
文件的Python(3.4)例程。但是,根据参数集,可能没有任何数据,在这种情况下,我不希望写入csv
文件。 (它只会用一个头文件写入文件)。如果没有数据,请勿使用csv DictWriter编写文件
现在,bandaid是计算生成后的行数,然后删除文件,但肯定必须有更好的方法,同时保留生成器是唯一的代码,它知道是否有数据给定参数,(也有两次在发电机调用):
def write_csv(csv_filename, fieldnames, generator, from_date, to_date, client=None):
with open(csv_filename, 'w', newline='') as csv_file:
csv_writer = csv.DictWriter(csv_file, fieldnames=fieldnames, delimiter='\t')
csv_writer.writeheader()
csv_writer.writerows(generator(from_date, to_date, client))
# If no rows were written delete the file, we don't want it
with open(csv_filename) as f:
lines = sum(1 for _ in f)
if lines == 1:
f.close()
os.remove(f.name)
def per_client_items_generator(from_date, to_date, client):
return (per_client_detail(client, sales_item) for sales_item in
sales_by_client.get(client))
您还可以看看http://stackoverflow.com/questions/661603/how-do-i-know-如果生成器是空的从一开始或http://stackoverflow.com/questions/3114252/one-liner-to-check-whether-an-iterator-yields-at-least-one-元件。 –