python、csv

.csv文件如何改变列的位置

        with open(SORTINFO_INPUT_FILE, 'r') as infile, open(SORTINFO_OUTPUT_EXCELNAME, 'a') as outfile:
        #,'レイヤ','コントロール/図形名','ビューフレーム内','種別','X','Y','WIDTH','HEIGHT','コメント'
        #fieldnames = ['ページ', 'スクリーン']
        fieldnames = ["ページ", "スクリーン"]

        writer = csv.DictWriter(outfile, fieldnames=fieldnames)
        writer.writeheader()
        for row in csv.DictReader(infile):
            writer.writerow(row)
    

报错ValueError: dict contains fields not in fieldnames: ''
这俩个csv文件初始状态内容是一样的,想把in里面的文件第一列和第二列颠倒一下放到out的文件内输出。不知道错在哪里.

看起来你想要从一个 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() 方法。