python3使用xlrd、xlwt合并多个Excel到一个文件

import xlrd
import xlwt

#打开一个Excel
def open_xls(file):
      fh=xlrd.open_workbook(file)
      return fh

#获取excel中所有的sheet表
def getsheet(fh):
      return fh.sheets()

#获取table的行数
def getnrows(fh,sheet):
      table=fh.sheets()[sheet]
      return table.nrows

#获取table的列数
def getcols(fh,sheet):
      table=fh.sheets()[sheet]
      return table.ncols

#获取sheet的个数
def get_sheet_num(fh):
      x=0
      for sheet in getsheet(fh):
            x+=1
      return x

#读取文件内容并返回行内容
def get_file(file,sheet_num):
      fh=open_xls(file)
      table=fh.sheets()[sheet_num]
      rows=table.nrows
      for row in range(rows):
            data=table.row_values(row)
            data_value.append(data)
      return data_value

if __name__=='__main__':
      files=['excel01.xls','excel02.xls']
      data_value=[]
      for file in files:
            fh=open_xls(file)
            sheet_num=get_sheet_num(fh)
            for num in range(sheet_num):
                  print("正在读取第"+str(file)+"的第"+str(num+1)+"张sheet表")
                  dataValue=get_file(file,num)
      #新的Excel文件
      newFile='excel03.xls'
      workbook=xlwt.Workbook(newFile)
      #创建一个sheet对象
      worksheet=workbook.add_sheet("mysheet")
      for i in range(len(dataValue)):
            for j in range(len(data_value[i])):
                  worksheet.write(i,j,data_value[i][j])
      workbook.save(newFile)
      print("合并结束.........")
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
实现多个Excel文件合并的方法主要有两种,一种是使用Python的pandas库,另一种是使用xlrdxlwt库。 下面分别介绍这两种方法的实现步骤: 1. 使用pandas库 首先需要安装pandas库,可以使用pip install pandas命令进行安装。 合并Excel文件的步骤如下: ① 导入pandas库和os库 ```python import pandas as pd import os ``` ② 定义一个函数,用于将多个Excel文件合并一个DataFrame对象 ```python def merge_excels(path): result = pd.DataFrame() for root, dirs, files in os.walk(path): for file in files: if file.endswith('.xlsx'): # 只处理xlsx文件 file_path = os.path.join(root, file) df = pd.read_excel(file_path) result = result.append(df) return result ``` ③ 调用merge_excels函数,将多个Excel文件合并一个DataFrame对象,并将结果保存到一个新的Excel文件中 ```python path = '/path/to/excels' result = merge_excels(path) result.to_excel('merged.xlsx', index=False) ``` 2. 使用xlrdxlwt库 需要先安装xlrdxlwt库,可以使用pip install xlrd xlwt命令进行安装。 合并Excel文件的步骤如下: ① 导入xlrdxlwt库 ```python import xlrd import xlwt import os ``` ② 定义一个函数,用于将多个Excel文件合并一个新的Excel文件 ```python def merge_excels(path): wb = xlwt.Workbook(encoding='utf-8') ws = wb.add_sheet('merged') row_num = 0 for root, dirs, files in os.walk(path): for file in files: if file.endswith('.xlsx'): # 只处理xlsx文件 file_path = os.path.join(root, file) workbook = xlrd.open_workbook(file_path) sheet = workbook.sheet_by_index(0) if row_num == 0: # 第一次循环需要写入表头 for i in range(sheet.ncols): ws.write(row_num, i, sheet.cell_value(0, i)) row_num += 1 for j in range(1, sheet.nrows): # 从第二行开始写入数据 for k in range(sheet.ncols): ws.write(row_num, k, sheet.cell_value(j, k)) row_num += 1 return wb ``` ③ 调用merge_excels函数,将多个Excel文件合并一个新的Excel文件,并保存到本地 ```python path = '/path/to/excels' wb = merge_excels(path) wb.save('merged.xls') ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值