首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何根据多列拆分csv

如何根据多列拆分csv
EN

Stack Overflow用户
提问于 2019-09-07 07:30:40
回答 2查看 190关注 0票数 2

我正在尝试根据两个列值将一个csv拆分为多个文件。例如,

源文件:

代码语言:javascript
复制
Header1  Header2             Header3
Alpha    energy              0.1
Alpha    energy              0.34
Beta     energy_imbalance    0.66
Beta     energy              0.7
Beta     energy              0.1
Gamma    energy_imbalance    0.3

预期输出:

Outfile1:

代码语言:javascript
复制
Header1  Header2             Header3
Alpha    energy              0.1
Alpha    energy              0.34

Outfile2:

代码语言:javascript
复制
Header1  Header2             Header3
Beta     energy_imbalance    0.66

Outfile3:

代码语言:javascript
复制
Header1  Header2             Header3
Beta     energy              0.7
Beta     energy              0.1

Outfile4:

代码语言:javascript
复制
Header1  Header2             Header3
Gamma    energy_imbalance    0.3

下面是我开始的内容:

代码语言:javascript
复制
filein = open('test.csv')
csvin = csv.DictReader(filein)

outputs = {}
for row in csvin:
    primaryValue = row['Header1']
    secondaryValue = row['Header2']
    if primaryValue not in outputs:
        fileout = open('{}_{}.csv'.format(primaryValue,secondaryValue),'w')
        dw = csv.DictWriter(fileout, fieldnames=csvin.fieldnames)
        dw.writeheader()
        outputs[primaryValue] = fileout, dw
    outputs[primaryValue][1].writerow(row)

for fileout, _ in outputs.values():
    fileout.close()

我能够根据column = Header1拆分文件,但是我不确定如何继续。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-09-07 10:00:45

下面是一个按照@Barmar的建议来实现的方法(只是它没有使用f-string来定义csv_files字典键值):

代码语言:javascript
复制
import csv


infile_name = 'test.csv'

with open(infile_name, newline='') as infile:
    reader = csv.DictReader(infile)
    csv_files = {}
    files = []

    for row in reader:
        key = '{}_{}'.format(row['Header1'], row['Header2'])
        if key not in csv_files:
            # Create the csv file
            outfile_name = '{}.csv'.format(key)
            fileout = open(outfile_name, 'w', newline='')
            writer = csv.DictWriter(fileout, fieldnames=reader.fieldnames)
            writer.writeheader()
            csv_files[key] = writer
            files.append(fileout)  # To close them later.

        # Write the line to corresponding csv writer.
        csv_files[key].writerow(row)

    # Close all csv output files.
    for f in files:
        f.close()

应用于示例输入文件,这将生成以下csv输出文件:

代码语言:javascript
复制
Alpha_energy.csv
Beta_energy.csv
Beta_energy_imbalance.csv
Gamma_energy_imbalance.csv

在它们中包含您所期望的数据。

票数 0
EN

Stack Overflow用户

发布于 2019-09-07 08:06:33

在这里试试这个:

代码语言:javascript
复制
csvin = csv.DictReader(filein)
csv_files = {}
files = []

for row in csvin:
    key = (row['Header1'], row['Header2'])
    if key not in csv_files:
        # create the csv file
        fileout = open('{}_{}.csv'.format(*key), 'w')
        dw = csv.DictWriter(fileout, fieldnames=csvin.fieldnames)
        dw.writeheader()
        csv_files[key] = dw
        files.append(fileout)  # to close them later

    # write the line into to corresponding csv writer
    csv_files[key].writerow(row)

# close all files
for f in files: f.close()
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57829530

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档