许下心愿* 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 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写
  • ¥20 Qcustomplot缩小曲线形状问题
  • ¥15 企业资源规划ERP沙盘模拟
  • ¥15 树莓派控制机械臂传输命令报错,显示摄像头不存在
  • ¥15 前端echarts坐标轴问题
  • ¥15 ad5933的I2C
  • ¥15 请问RTX4060的笔记本电脑可以训练yolov5模型吗?
  • ¥15 数学建模求思路及代码
  • ¥50 silvaco GaN HEMT有栅极场板的击穿电压仿真问题