最近看视频学习,老师布置了个作业,关于如何使用python将多个excel进行合并,老师写的代码我感觉比较复杂,下面是我自己改良之后较简单的方式。

实现这个功能主要有两种方法,一种是用xlwd,xlsxwriter库结合,不管是xlsx,xls都是适用的;另一种是openpyxl,这个库只对xlsx有效。

本文针对第一种方式进行讲解。

首先准备三个excel文件,目的是将三个excel的sheet进行合并:

test_excel1.xlsx

为了简化测试,另外两个excel文件test_excel2.xlsx, test_excel3.xlsx的内容跟第一个excel是一致的。

下面是代码部分

-- coding:utf-8 --

import xlrd,xlsxwriter

待合并excel

allxls=["E:\python3_hellobi_work\excel\test_excel\test_excel1.xlsx",

"E:\python3_hellobi_work\excel\test_excel\test_excel2.xlsx",

"E:\python3_hellobi_work\excel\test_excel\test_excel3.xlsx"]

目标excel

end_xls="E:\python3_hellobi_work\excel\test_excel\final_excel.xlsx"

def open_xls(file):

try:

fh=xlrd.open_workbook(file)

return fh

except Exception as e:

print("打开文件错误:"+e)

根据excel名以及第几个标签信息就可以得到具体标签的内容

def get_file_value(filename,sheetnum):

rvalue=[]

fh=open_xls(filename)

sheet=fh.sheets()[sheetnum]

row_num=sheet.nrows

for rownum in range(0,row_num):

rvalue.append(sheet.row_values(rownum))

return rvalue

获取第一个excel的sheet个数以及名字作为标准

first_file_fh=open_xls(allxls[0])

first_file_sheet=first_file_fh.sheets()

first_file_sheet_num=len(first_file_sheet)

sheet_name=[]

for sheetname in first_file_sheet:

sheet_name.append(sheetname.name)

定义一个目标excel

endxls=xlsxwriter.Workbook(end_xls)

all_sheet_value=[]

把所有内容都放到列表all_sheet_value中

for sheet_num in range(0,first_file_sheet_num):

all_sheet_value.append([])

for file_name in allxls:

print("正在读取"+file_name+"的第"+str(sheet_num+1)+"个标签...")

file_value=get_file_value(file_name,sheet_num)

all_sheet_value[sheet_num].append(file_value)

print(all_sheet_value)

num=-1

sheet_index=-1

将列表all_sheet_value的内容写入目标excel

for sheet in all_sheet_value:

sheet_index+=1

end_xls_sheet=endxls.add_worksheet(sheet_name[sheet_index])

num+=1

num1=-1

for sheet1 in sheet:

for sheet2 in sheet1:

num1+=1

num2=-1

for sheet3 in sheet2:

num2+=1

#print(num,num1,num2,sheet3)

#在第num1行的第num2列插入sheet3内容

end_xls_sheet.write(num1,num2,sheet3)

记得要关闭文件

endxls.close()

----------------------------------------------end--------------------------------------------------------------

运行代码,看看目标excel:

两个excel已经合并到一起了。

哈哈。写完啦~~~

使用python将多个excel合并的更多相关文章

  1. Python将多个excel表格合并为一个表格

    Python将多个excel表格合并为一个表格 生活中经常会碰到多个excel表格汇总成一个表格的情况,比如你发放了一份表格让班级所有同学填写,而你负责将大家的结果合并成一个.诸如此类的问题有很多.除 ...

  2. Python使用openpyxl读写excel文件

    Python使用openpyxl读写excel文件 这是一个第三方库,可以处理xlsx格式的Excel文件.pip install openpyxl安装.如果使用Aanconda,应该自带了. 读取E ...

  3. python 导出数据到excel 中,一个好用的导出数据到excel模块,XlsxWriter

    最近公司有项目需要导出数据到excel,首先想到了,tablib,xlwt,xlrd,xlwings,win32com[还可以操作word],openpyxl,等模块但是 实际操作中tablib 写入 ...

  4. 【转发】Python使用openpyxl读写excel文件

    Python使用openpyxl读写excel文件 这是一个第三方库,可以处理xlsx格式的Excel文件.pip install openpyxl安装.如果使用Aanconda,应该自带了. 读取E ...

  5. python读写word、excel、csv、json文件

    http://blog.csdn.net/pipisorry/article/details/50368044 python读写word文档 (include wps)将word文档转换成txt文档 ...

  6. Python利用pandas处理Excel数据的应用

    Python利用pandas处理Excel数据的应用   最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做 ...

  7. python将两个数组合并成一个数组的两种方法的代码

    内容过程中,把写内容过程中常用的内容收藏起来,下面的资料是关于python将两个数组合并成一个数组的两种方法的内容,希望能对小伙伴们有帮助. c1 = ["Red","G ...

  8. python使用xlrd读取excel数据时,整数变小数的解决办法

    python使用xlrd读取excel数据时,整数变小数: 解决方法: 1.有个比较简单的就是在数字和日期的单元格内容前加上一个英文的逗号即可.如果数据比较多,也可以批量加英文逗号的前缀(网上都有方法 ...

  9. 【python-excel】Selenium+python自动化之读取Excel数据(xlrd)

    Selenium2+python自动化之读取Excel数据(xlrd) 转载地址:http://www.cnblogs.com/lingzeng86/p/6793398.html ·········· ...

随机推荐

  1. Azure 基础:用 PowerShell 自动登录

    PowerShell 是管理 Azure 的最好方式,因为我们可以使用脚本把很多的工作自动化.比如把 Azure 上的虚拟机关机,并在适当的时间把它开机,这样我们就能节省一些开支,当然我们同时也为减少 ...

  2. PHP程序员的技术成长之路规划

    按照了解的很多PHP/LNMP程序员的发展轨迹,结合个人经验体会,抽象出很多程序员对未来的迷漫,特别对技术学习的盲目和慌乱,简单梳理了这个每个阶段PHP程序员的技术要求,来帮助很多PHP程序做对照设定 ...

  3. CSS基础:基础和语法

    **CSS语法** CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明.选择器通常是您需要改变样式的 HTML 元素.```selector {declaration1; declarati ...

  4. 前端安全之CSRF攻击

    前端安全之CSRF攻击 转载请注明出处:unclekeith: 前端安全之CSRF攻击 CSRF定义 CSRF,即(Cross-site request forgery), 中文名为跨站请求伪造.是一 ...

  5. 编译安装PHP 时遇到问题解决方法.

    编译安装PHP时出现下面的错误代码: error 2 checking for pkg-config... /usr/bin/pkg-config configure: error: Cannot f ...

  6. 实现 node_modules 共享

    参考:https://segmentfault.com/a/1190000000610038 Gruntjs 作为前端工程化工具,能够很好的对前端资源进行管理(校验,合并,压缩). 久之,发现一个问题 ...

  7. Formatting the event object

    尽量将IE与DOM函数事件对象不同的性质或方法转成DOM标准   EventUtil.formatEvent = function (oEvent) {    if (isIE && ...

  8. 微信小程序异步处理

    直接看问题: 然后看打印的结果: 根据上面两图可以看出,代码上先执行的网络请求,再执行打印的变量,但是从下面打印的结果来看,先出结果的是执行打印变量的函数(aafn函数),再打印出网络请求succes ...

  9. 前端基于react,后端基于.net core2.0的开发之路(2) 开发环境的配置,注意事项,后端数据初始化

    前端环境配置 项目介绍文章:前端基于react,后端基于.net core2.0的开发之路(1) 介绍 1.VSCode安装 下载地址:https://code.visualstudio.com/Do ...

  10. [转载] JaCoCo:分析单元测试覆盖率的利器

    转载自http://www.ibm.com/developerworks/cn/java/j-lo-jacoco/和http://www.cnblogs.com/chenfengmugu/p/4937 ...