按行数拆分CSV文件并保留头部
创始人
2024-08-22 06:00:55
0

下面是一个示例代码,可以按行数拆分CSV文件并保留头部:

import csv

def split_csv(input_file, output_path, rows_per_file):
    with open(input_file, 'r') as file:
        reader = csv.reader(file)
        header = next(reader)  # 读取头部

        file_index = 1
        row_count = 0
        output_file = None

        for row in reader:
            if output_file is None or row_count >= rows_per_file:
                if output_file is not None:
                    output_file.close()
                output_file = open(f'{output_path}/{file_index}.csv', 'w', newline='')
                writer = csv.writer(output_file)
                writer.writerow(header)  # 写入头部
                file_index += 1
                row_count = 0

            writer.writerow(row)
            row_count += 1

        if output_file is not None:
            output_file.close()

# 示例用法
split_csv('input.csv', 'output', 1000)

上述代码中,split_csv函数接受三个参数:输入文件路径、输出文件夹路径和每个输出文件的行数限制。函数使用CSV模块读取输入文件,并逐行处理。

在处理行数达到限制或需要新的输出文件时,函数会关闭当前的输出文件(如果有),并创建一个新的输出文件。在每个输出文件中,函数会先写入头部,然后逐行写入行数据。

在示例中,split_csv('input.csv', 'output', 1000)将会读取名为input.csv的输入文件,将其拆分成每个文件最多包含1000行的输出文件,并保存到名为output的文件夹中。

相关内容

热门资讯

透视能赢!哈糖大菠萝怎么挂(透... 透视能赢!哈糖大菠萝怎么挂(透视)果然真的有挂(详细辅助第三方教程)1、金币登录送、破产送、升级送、...
教程辅助!pokerworld... 教程辅助!pokerworld修改器,wejoker辅助器怎么卖,扑克教程(有挂技巧);1.wejo...
辅助透视!佛手大菠萝有挂吗(透... 辅助透视!佛手大菠萝有挂吗(透视)原来有挂(详细辅助科技教程)辅助器中分为三种模型:软件透明挂、辅助...
一分钟揭秘!aapoker辅助... 一分钟揭秘!aapoker辅助软件合法吗,wepoker辅助器安装包,扑克教程(有挂透视);科技安装...
透视规律!智星德州插件2024... 透视规律!智星德州插件2024最新版(透视)总是真的是有挂(详细辅助扑克教程)1、用户打开应用后不用...
三分钟了解!德州hhpoker... 三分钟了解!德州hhpoker脚本,wepoker私人局透视插件,力荐教程(有挂软件);1.wepo...
透视有挂!wepoker底牌透... 透视有挂!wepoker底牌透视(透视)其实真的有挂(详细辅助力荐教程)1)辅助挂:进一步探索辅助透...
大家学习交流!wepoker私... 大家学习交流!wepoker私人局怎么玩,we poker辅助器,高科技教程(有挂技巧)1、玩家可以...
透视透视!wepoker透视有... 透视透视!wepoker透视有吗(透视)原来真的是有挂(详细辅助爆料教程);1、进入到wepoker...
重大通报!pokemmo辅助工... 1、重大通报!pokemmo辅助工具,wepoker私局辅助,科技教程(有挂辅助)。2、pokemm...