Python?合并/拆分Excel的實現(xiàn)示例
更新時間:2023年09月21日 16:24:49 作者:gongzairen
有時對于多個工作表需要進行合并或拆分,以便進行瀏覽總結(jié),本文主要介紹了Python?合并/拆分Excel的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
python對于合并excel本篇文章給出合并xlsx文件的方法,xls的方法不在本文介紹
拆分數(shù)據(jù)可以適用于xlsx或xls
合并excel
先讀取所有的excel,得到df列表,在將這個df列表 按行進行合并
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文件,無法讀取數(shù)據(jù)")
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,無法合并數(shù)據(jù)")
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
按照指定的行數(shù)對原表的數(shù)據(jù)進行拆分,拆分的數(shù)據(jù)每一個表格會保留表頭(標題行)
import xlrd
import xlwt
import pandas as pd
# 拆分數(shù)據(jù)
def split_file(file_path):
"""
將傳入的xls文件格式的表格進行,按照指定行數(shù)進行拆分
:return: 返回拆分后的文件路徑列表
"""
if file_path is None:
print("沒有需要拆分的表格")
return
split_rows = 500 # 每個表拆分數(shù)據(jù)的行數(shù)
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) # 寫入數(shù)據(jù)
workbook.save(filename)
print(f"拆分的文件路徑:{filename}")
your_file_path = "需要拆分的表格路徑"
split_file(your_file_path )到此這篇關(guān)于Python 合并/拆分Excel的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)Python 合并/拆分Excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python 二叉樹的層序建立與三種遍歷實現(xiàn)詳解
這篇文章主要介紹了Python 二叉樹的層序建立與三種遍歷實現(xiàn)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07

