许下心愿* 2023-01-09 18:28 采纳率: 100%
浏览 25
已结题

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的文件内输出。不知道错在哪里.

  • 写回答

2条回答 默认 最新

  • m0_54204465 2023-01-09 18:43
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月19日
  • 已采纳回答 1月11日
  • 创建了问题 1月9日

悬赏问题

  • ¥15 stc15f2k60s2单片机关于流水灯,时钟,定时器,矩阵键盘等方面的综合问题
  • ¥15 YOLOv8已有一个初步的检测模型,想利用这个模型对新的图片进行自动标注,生成labellmg可以识别的数据,再手动修改。如何操作?
  • ¥30 NIRfast软件使用指导
  • ¥20 matlab仿真问题,求功率谱密度
  • ¥15 求micropython modbus-RTU 从机的代码或库?
  • ¥15 django5安装失败
  • ¥15 Java与Hbase相关问题
  • ¥15 后缀 crn 游戏文件提取资源
  • ¥20 bash代码推送不上去 git fetch origin master #失败了
  • ¥15 LOL外服加入了反作弊系统,现在游戏录像rofl文件离线都无法打开