看起来你想要从一个 CSV 文件中读取一些行,并将它们写入另一个 CSV 文件中。正在使用 csv 模块的 DictReader 和 DictWriter 类。DictReader 类返回一个字典,其中键是 CSV 文件中的列标题,并将该字典传递给 DictWriter 类的 writerow() 方法。
但是,正在为 DictWriter 类提供的“ fieldnames”参数提供的列名列表["ページ", "スクリーン"] 与 DictReader 类返回的字典中包含的键不匹配。如果 DictReader 类返回的字典中的任何键不在 DictWriter 类的“ fieldnames”参数中,则会引发 ValueError。
因此,要解决此错误,请确保 DictWriter 类的“ fieldnames”参数包含 DictReader 类返回的字典中包含的所有键。例如,可以使用 DictReader 类的 fieldnames 属性来获取列标题列表:
with open(SORTINFO_INPUT_FILE, 'r') as infile, open(SORTINFO_OUTPUT_EXCELNAME, 'a') as outfile:
reader = csv.DictReader(infile)
fieldnames = reader.fieldnames
writer = csv.DictWriter(outfile, fieldnames=fieldnames)
writer.writeheader()
for row in reader:
writer.writerow(row)
如果您希望将 CSV 文件中的列按不同顺序写入输出文件,可以指定“ fieldnames”参数中的列顺序。例如,如果你想要将 CSV 文件的第一列和第二列颠倒,可以这样做:
with open(SORTINFO_INPUT_FILE, 'r') as infile, open(SORTINFO_OUTPUT_EXCELNAME, 'a') as outfile:
reader = csv.DictReader(infile)
fieldnames = ["スクリーン", "ページ"] # 按照这个顺序写入输出文件
writer = csv.DictWriter(outfile, fieldnames=fieldnames)
writer.writeheader()
for row in reader:
writer.writerow({fieldname: row[fieldname] for fieldname in fieldnames})
这里的代码使用了一个字典推导式,它创建了一个新字典,其中包含所有键和与其对应的值。这个字典推导式将输入字典中的所有键值对重新按照指定顺序排列,并将该字典传递给 DictWriter 的 writerow() 方法。