Python合并和拆分excel

合并excel

这里写图片描述

import pandas as pd, os
cwd = os.getcwd()  # 当前目录
og_dir = cwd + '/origin/'  # 存放待合并的excel
og_ls = os.listdir(og_dir)  # 所有excel名称
cb_name = 'combine.xlsx'  # 合并后的文件名
# 合并
excel_ls = []
for f in og_ls:
    excel_ls.append(pd.read_excel(og_dir + f))
df0 = pd.concat(excel_ls)
df0.to_excel(cb_name, index=False)

拆分excel

在这里插入图片描述
在这里插入图片描述

import os, pandas as pd
b_dir = 'before/'  # 放置待拆分的excel(限1个)
fname = b_dir + os.listdir(b_dir)[0]  # 待拆分的excel的文件名
a_dir = 'after/'  # 放置拆分后的excel
def split_xlsx(col=0):  # 按列序拆
    df = pd.read_excel(fname)
    field = df.columns[col]
    unique = df[field]
    for u in unique:
        df[df[field] == u].to_excel(a_dir + '{}.xlsx'.format(u), index=False)
split_xlsx()

基础补充

1、合并DataFrame

  • 相同列合并
    在这里插入图片描述
import pandas as pd
import numpy as np
df1 = pd.DataFrame(np.array(range(8)).reshape(2, 4), columns=list('ABCD'))
df2 = pd.DataFrame(np.array(range(100, 108)).reshape(2, 4), columns=list('ABCD'))
df3 = pd.concat([df1, df2])
print(df1, df2, df3, sep='\n\n')
  • 相同行合并:axis=1

2、pandas基础

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小基基o_O

您的鼓励是我创作的巨大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值