将文件夹下所有excel写入同一个excel多个sheet

import xlrd,xlwt
import os,shutil
from xutils.copy import copy

def get_all_excel(path):
    # 获取当前路径下所有excel
    # 返回al1_excel 是excel路径,all_name 是所有excel名字
    folder = os.walk(path)
    folder = list(folder)
    al1_name = [i.split('.')[0] for i in folder[0][2:][0]]
    all_excel = [path + '1' + i for i in folder[0][2:][0]]
    return all_excel, al1_name

def xlrd_read_allsheet(filename):
    # 读取所有excel中所有sheet名字
    # :return: excel名_sheet名:excel中数据

    # 读取所有的sheet内容 iparam filename:

     workbook = xlrd.open_workbook(filename)
     names = workbook.sheet_names()# 返回所有Sheet的名字 name_data=0# 创建字典
     name_data={}
     for name in names: # 遍历当前excel下所有的sheet
        table = workbook.sheet_by_name(name)
        rows = table.nrows
        cols = table.ncols
        al1_data = []
        for row in range(rows):
            inner_data = []
            for col in range(cols):
                inner_data.append(table.cell_value(row, col))
            al1_data.append(inner_data) # 单个sheet数据 name_data[filename,split()[-1].split0,)[0]	 name] = all data # excel
        name_data[filename.split('\\')[-1].split('.')[0]+'_'+name]=al1_data
     return name_data

def xlwt_write(data, path,	 sheet_name, title=None):
    try:
        workbook= copy(xlrd.open_workbook(path))# 若写入的excel存在 
    except:
        workbook= xlwt.Workbook()# 若写入的excel不存在,则创建excel 
    worksheet = workbook.add_sheet(sheet_name)# 使用原excel名称+sheet 
    if title: # 如果表头存在,写入表头,不存在则pass
        for row in range(len(data)):
            for col in range(len(data[row])):
                worksheet.write(row+ 1,col, data[row][col])
    else:# 写Aexcel
        for row in range(len(data)):
            for col in range(len(data[row])):
                worksheet.write(row, col,data[row][col])
    workbook.save(path)
    return path + '写入成功'

# 调用
def run():
    path = r'E:\下载表'
    all_excel,all_name = get_all_excel(path)
    excel_data =[]
    for filename in all_excel:
        name_data = xlrd_read_allsheet(filename) 
        excel_data.append(name_data)
    for excel in range(len(excel_data)):
        for k, v in excel_data[excel].items():
            xlwt_write(v, r'result.xLsx', sheet_name = k.split('_')[0] +"_"+str(excel))

    return 

run()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
你可以使用 Python 中的 pandas 库来读取同一文件夹下的多个 Excel 文件,并从中提取需要的数据,然后将这些数据写入一个新的 Excel 文件。下面是一个示例代码: ```python import os import pandas as pd # 设置文件夹路径 folder_path = '/path/to/folder' # 获取文件夹中所有的 Excel 文件 excel_files = [f for f in os.listdir(folder_path) if f.endswith('.xlsx')] # 创建一个空的 DataFrame 用于存储所有数据 data = pd.DataFrame() # 循环遍历每个 Excel 文件,提取需要的数据 for file in excel_files: file_path = os.path.join(folder_path, file) df = pd.read_excel(file_path, sheet_name='Sheet1') # 提取第一列和第三列的数据,并将它们合并到 data DataFrame 中 data = pd.concat([data, df.iloc[:, [0, 2]]], axis=0) # 将 data 中的数据写入一个新的 Excel 文件 output_file = '/path/to/output.xlsx' data.to_excel(output_file, index=False) ``` 在这个示例代码中,我们首先设置了文件夹路径并获取了所有的 Excel 文件。接下来,我们循环遍历每个 Excel 文件,使用 pandas 库的 read_excel() 函数读取每个文件中的数据。在这个示例中,我们假设数据位于每个 Excel 文件的第一张工作表 (Sheet1) 中,并且我们需要提取每个文件中的第一列和第三列的数据。我们使用 iloc 属性来选择需要的列,并将它们合并到一个名为 data 的 DataFrame 中。最后,我们将 data 中的数据写入一个新的 Excel 文件,这个文件的路径是 '/path/to/output.xlsx'。 注意,在这个示例中,我们使用了 concat() 函数将每个 Excel 文件中提取的数据合并到一个 DataFrame 中。在实际应用中,你可能需要根据数据的特点来选择合适的合并方法,例如使用 merge() 函数或 join() 函数。此外,在写入新的 Excel 文件时,你可以使用 to_excel() 函数来指定需要写入的工作表名称,例如 data.to_excel(output_file, sheet_name='Sheet1')。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值