Python 合并/拆分Excel

news/2024/7/21 7:11:56 标签: python, excel, 开发语言

python对于合并excel本篇文章给出合并xlsx文件的方法,xls的方法不在本文介绍

拆分数据可以适用于xlsx或xls

合并excel

        先读取所有的excel,得到df列表,在将这个df列表 按行进行合并

python">import pandas as pd


# 读取所有xlsx
def read_xlsx(xlsx_list):
    """
    :param xlsx_list: xlsx文件列表
    :return: 
    """
    if len(xlsx_list) == 0 or xlsx_list is None:
        print("没有任何xlsx文件,无法读取数据")
        return
    
    df_list = []
    for xlsx in xlsx_list:
        df = pd.read_excel(xlsx)
        df_list.append(df)
    return df_list


# 合并xlsx
def merge_xlsx(df_list):
    """
    :param df_list: df列表
    :return: 
    """
    if len(df_list) == 0 or df_list is None:
        print("没有任何df,无法合并数据")
        return

    merged_df = pd.concat(df_list, axis=0)
    xlsx_path = "文件保存路径"
    merged_df.to_excel(xlsx_path, index=False)
    return xlsx_path


file_list = ["xlsx文件路径1","xlsx文件路径2","xlsx文件路径3","xlsx文件路径4"]
read_df_list = read_xlsx(file_list)
merged_file = merge_xlsx(read_df_list)
print(f"合并后的文件路径:{merged_file}")

拆分excel

        按照指定的行数对原表的数据进行拆分,拆分的数据每一个表格会保留表头(标题行)

python">import xlrd
import xlwt
import pandas as pd


# 拆分数据
def split_file(file_path):
    """
    将传入的xls文件格式的表格进行,按照指定行数进行拆分
    :return: 返回拆分后的文件路径列表
    """
    
    if file_path is None:
        print("没有需要拆分的表格")
        return

    split_rows = 500  # 每个表拆分数据的行数
    wb = xlrd.open_workbook(file_path)
    sheet = wb.sheet_by_index(0)
    total_rows = sheet.nrows
    split_size = split_rows + 1
    header = sheet.row_values(0)

    # 拆分大于指定的长度的文件
    first_file = True
    for i in range(total_rows // split_size):
        if first_file:  # 如果是第一个文件则从第二行开始(跳过表头)
            start_row = i * split_size + 1
            first_file = False
        else:
            start_row = i * split_size

        end_row = start_row + split_rows
        data = [sheet.row_values(j) for j in range(start_row, end_row)]
        filename = f'拆分的文件_{i + 1}.xls'

        workbook = xlwt.Workbook()
        sheet_new = workbook.add_sheet("Sheet1")
        for col_index, value in enumerate(header):
            sheet_new.write(0, col_index, value)  # 写入表头
        for row_index, row in enumerate(data):
            for col_index, value in enumerate(row):
                sheet_new.write(row_index + 1, col_index, value)  # 写入数据
        workbook.save(filename)
        print(f"拆分的文件路径:{filename}")


your_file_path = "需要拆分的表格路径"
split_file(your_file_path )


http://www.niftyadmin.cn/n/5037185.html

相关文章

Retrofit项目 - Android和Java的类型安全的HTTP客户端

A type-safe HTTP client for Android and Java 官网&#xff1a;Retrofit Retrofit turns your HTTP API into a Java interface. public interface GitHubService { GET("users/{user}/repos") Call<List<Repo>> listRepos(Path("user"…

vscode的Emmet语法失效

解决方案&#xff1a;设置 -> 搜索Emmet -> 勾选 Emmet:Trigger Expansion On Tab和Emmet: Use Inline Completions -> 重启 注&#xff1a;Emmet语法是vscode自带的语法&#xff0c;可以快速生成HTML结构/CSS样式/格式化语法 Emmet语法 参考&#xff1a;关于vscode使…

从键盘任意输出一个整数n,若n不是素数,则计算并输出其所有因子(不包括1),否则输出该数为素数

#include<stdio.h> int main() {int i 0;int j 0;int n 0;int tag 0;//设置一个标志位&#xff0c;不为素数时令tag1&#xff1b;printf("输入一个数&#xff1a;");scanf("%d", &n);for (i 2; i < n; i){if (n % i 0){printf("该…

展示日志log4.properties

log4.properties 1.log4.properties 此时文件主要用于展示日志的输出的级别的信息。 # Set root category priority to INFO and its only appender to CONSOLE. #log4j.rootCategoryINFO, CONSOLE debug info warn error fatal log4j.rootCategoryinfo, CONSO…

全渠道零售趋势——现代零售业成功的关键

在快节奏的零售时代&#xff0c;无论通过什么渠道购物&#xff0c;消费者越来越习惯无缝购物体验。因此&#xff0c;保持线上和线下购物体验的一致性有助于在品牌与购物者之间建立信任&#xff0c;这也是每个零售商的首要任务。在本文中&#xff0c;我们将介绍现代零售业成功的…

PMP-项目收尾过程组的重要性

一、什么是项目收尾过程组 收尾过程组包括为正式完成或关闭项目、阶段或合同而开展的过程。本过程组旨在核实为完成项目或阶段所需的所有过程组的全部过程均已完成&#xff0c;并正式宣告项目或阶段关闭。本过程组的主要作用是&#xff0c;确保恰当地关闭阶段、项目和合同。虽然…

华为OD:求字符串中所有整数的最小和

输入字符串s&#xff0c;输出s中包含所有整数的最小和。 说明&#xff1a; 字符串s&#xff0c;只包含a-z A-Z-&#xff1b; 合法的整数包括&#xff1a; 正整数一个或者多个0-9组成&#xff0c;如 0 2 3 002 202负整数负号-开头&#xff0c;数字部分由一个或者多个0-9组成…

从利用Arthas排查线上Fastjson问题到Java动态字节码技术(下)

上一篇从Arthas的源码引出了Java动态字节码技术&#xff0c;那么这一篇就从几种Java字节码技术出发&#xff0c;看看Arthas是如何通过动态字节码技术做到无侵入的源码增强&#xff1b; Java大部分情况下都是解释执行的&#xff0c;也就是解释.class文件&#xff0c;所以如果我们…