pandas批量拆分、合并EXCEl

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

提示:这里可以添加本文要记录的大概内容:

将一个EXCEL等份拆成多个EXCEL
将多个小EXCEL合并成一个大EXCEL并标记来源


提示:以下是本篇文章正文内容,下面案例可供参考

一、拆分成小表格

代码如下(示例):

import pandas as pd
import os
work_dir=r"G:\360Downloads\myself\zuoye\合并拆分"
splits_dir=f"{work_dir}\splits"
#如果不存在splits文件夹则创建它
if not os.path.exists(splits_dir):
    os.mkdir(splits_dir)
#引入源文件
df_source=pd.read_excel(f"{work_dir}/5月份台账.xlsx",sheet_name="5月份台账87334",skiprows=2)
df_source.head(3)
df_source.index
df_source.shape
total_row_count=df_source.shape[0]
total_row_count
#拆分成多个大小相同的excel
#1.使用df.iloc方法
#2.使用dataframe.to_excel保存到每个小excel中
#计算拆分后小excel的行数
user_names=["xiaoA","xiaoB","xiaoC","wmy","jzz","xmw"]
#每个人的任务数
split_size=total_row_count//len(user_names)
if total_row_count%len(user_names)!=0:
    split_size+=1
split_size
#拆分多个dataframe
df_subs=[]
#enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列
for idx,user_name in enumerate(user_names):
    #iloc的开始索引
    begin=idx*split_size
    #iloc的结束索引
    end=begin+split_size
    #实现df按照iloc拆分
    df_sub=df_source.iloc[begin:end]
    #将每个子df存入列表
    df_subs.append((idx,user_name,df_sub))
#将每个dataframe存入excel
for idx,user_name,df_sub in df_subs:
    filename=f"{splits_dir}/ee_{idx}_{user_name}.xlsx"
    df_sub.to_excel(filename,index=False)


在这里插入图片描述

二、合并excel

1.介绍

1、遍历文件夹,得到要合并的excel文件列表
2、分别读取到dataframe,给每一列标记来源
3、使用pd.conca进行df批量合并
4、将合并后的dataframe输出到excel

2.代码

代码如下(示例):

import pandas as pd
import os
work_dir=r"G:\360Downloads\myself\zuoye\合并拆分"
splits_dir=f"{work_dir}\splits"
#如果不存在splits文件夹则创建它
if not os.path.exists(splits_dir):
    os.mkdir(splits_dir)
#遍历文件夹,得到要合并的excel名称列表
excel_names=[]
for excel_name in os.listdir(splits_dir):
    excel_names.append(excel_name)
excel_names
df_list=[]
for excel_name in excel_names:
    #读取每个excel到df
    excel_path=f"{splits_dir}/{excel_name}"
    df_split=pd.read_excel(excel_path)
    username=excel_name.replace("ee_","").replace(".xlsx","")[2:]
    print(excel_name,username)
    #添加列,用户名字
    df_split["username"]=username
    df_list.append(df_split)
#concat合并
df_merged=pd.concat(df_list)
df_merged.shape
df_merged.head()
df_merged["username"].value_counts()
#输出
df_merged.to_excel(f"{work_dir}/merged.xlsx",index=False)

在这里插入图片描述


总结

提示:这里对文章进行总结:
个人python基础不是很牢固

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用PandasExcelWriter和openpyxl模块来拆分合并单元格。 首先,打开Excel文件并读取数据: ```python import pandas as pd # 读取Excel文件 df = pd.read_excel('data.xlsx') ``` 接下来,按省份拆分数据: ```python # 按省份拆分数据 for province in df['省份'].unique(): # 获取该省份的所有行数据 province_data = df[df['省份'] == province] # 将省份作为文件名 file_name = f'{province}.xlsx' # 创建ExcelWriter writer = pd.ExcelWriter(file_name, engine='openpyxl') # 将数据写入Excel文件 province_data.to_excel(writer, index=False) # 关闭ExcelWriter writer.save() ``` 然后,按省份合并单元格: ```python from openpyxl import load_workbook # 合并单元格 for province in df['省份'].unique(): # 获取该省份的文件名 file_name = f'{province}.xlsx' # 加载Excel文件 wb = load_workbook(file_name) ws = wb.active # 遍历每个单元格 for row in range(2, ws.max_row + 1): # 如果该单元格与上一个单元格的值相同,则合并 if ws.cell(row=row, column=1).value == ws.cell(row=row-1, column=1).value: ws.cell(row=row, column=1)._style = ws.cell(row=row-1, column=1)._style ws.merge_cells(start_row=row-1, end_row=row, start_column=1, end_column=1) # 保存Excel文件 wb.save(file_name) ``` 最后,将所有省份的数据合并到一个Excel文件中: ```python # 合并所有省份数据 writer = pd.ExcelWriter('all_data.xlsx', engine='openpyxl') for province in df['省份'].unique(): # 获取该省份的文件名 file_name = f'{province}.xlsx' # 加载Excel文件 province_data = pd.read_excel(file_name) # 将数据写入Excel文件 province_data.to_excel(writer, sheet_name=province, index=False) # 删除该省份的Excel文件 os.remove(file_name) # 关闭ExcelWriter writer.save() ``` ### 回答2: pandas是一种强大的数据处理工具,可以帮助我们对Excel文件进行各种操作。在Excel中,有时我们需要按省份拆分合并单元格,可以使用pandas来完成这个任务。 首先,我们需要导入pandas库,并读取Excel文件。可以使用pandas的read_excel()函数来读取Excel文件,并将其转换为DataFrame对象。接下来,我们可以查看DataFrame对象的列名,以确定需要进行拆分合并的列和行。在本例中,我们将假设省份信息保存在名为“省份”的列中。 一种常见的拆分合并单元格的方式是将相同省份的行进行合并,并将省份信息显示在一个单元格中。在pandas中,可以使用groupby()函数按照省份进行分组,并使用agg()函数进行聚合操作。具体代码如下: ```python import pandas as pd # 读取Excel文件 df = pd.read_excel('file.xlsx') # 按省份进行分组 grouped = df.groupby('省份') # 合并单元格并显示省份信息 df_merged = grouped.agg({'省份': lambda x: ''.join(x)}).reset_index() # 输出结果到Excel文件 df_merged.to_excel('merged_file.xlsx', index=False) ``` 上述代码中,我们首先使用groupby()函数按照“省份”列进行分组,并使用agg()函数对分组后的数据进行聚合操作。其中,lambda函数用于将每个分组中的省份信息拼接成一个字符串。然后,我们使用reset_index()函数重置索引,并将结果保存到df_merged中。 最后,我们可以使用to_excel()函数将合并后的结果保存为一个新的Excel文件。其中,index=False表示不将索引列保存到Excel文件中。 通过使用pandas的功能,我们可以方便地对Excel文件进行拆分合并单元格的操作,提高数据处理的效率和准确性。 ### 回答3: 使用Pandas库可以很方便地对Excel中的数据进行处理。对于按省份拆分合并单元格的操作,可以参考以下步骤: 1. 导入所需的库和模块,包括pandas和openpyxl: ``` import pandas as pd from openpyxl import load_workbook ``` 2. 使用`pd.read_excel()`方法读取Excel文件: ``` df = pd.read_excel('数据.xlsx') ``` 3. 根据省份列将数据进行拆分,可以使用`groupby()`方法对省份列进行分组: ``` grouped = df.groupby('省份') ``` 4. 使用`as_index=False`参数将省份设置为索引列,并将分组后的数据保存到一个新的DataFrame中: ``` new_df = grouped.apply(lambda x: x.set_index('省份', drop=False)).rename_axis(None) ``` 5. 对新的DataFrame中的省份列进行合并单元格的操作,可以使用openpyxl库中的Worksheet对象来实现: ``` writer = pd.ExcelWriter('新数据.xlsx', engine='openpyxl') writer.book = load_workbook('新数据.xlsx') new_df.to_excel(writer, sheet_name='Sheet1', merge_cells=True, startrow=1) worksheet = writer.sheets['Sheet1'] for cell_range in worksheet.merged_cells.ranges: worksheet.unmerge_cells(str(cell_range)) writer.save() ``` 通过以上步骤,我们可以将Excel文件中的数据按照省份进行拆分,并将相同省份的行合并为单元格。最后,我们将处理后的数据保存到一个新的Excel文件中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值