python如何读取多个excel合并到一个excel中

思路

利用python xlrd包读取excle文件,然后将文件内容存入一个列表中,再利用xlsxwriter将内容写入到一个新的excel文件中。

完整代码

# -*- coding: utf-8 -*-#将多个Excel文件合并成一个import xlrdimport xlsxwriter#打开一个excel文件def open_xls(file):

fh=xlrd.open_workbook(file)    return fh#获取excel中所有的sheet表def getsheet(fh):

return fh.sheets()#获取sheet表的行数def getnrows(fh,sheet):

table=fh.sheets()[sheet]    return table.nrows#读取文件内容并返回行内容def getFilect(file,shnum):

fh=open_xls(file)

table=fh.sheets()[shnum]

num=table.nrows    for row in range(num):

rdata=table.row_values(row)

datavalue.append(rdata)    return datavalue#获取sheet表的个数def getshnum(fh):

x=0

sh=getsheet(fh)    for sheet in sh:

x =1

return xif __name__=='__main__':    #定义要合并的excel文件列表

allxls=['F:/test/excel1.xlsx','F:/test/excel2.xlsx']    #存储所有读取的结果

datavalue=[]    for fl in allxls:

fh=open_xls(fl)

x=getshnum(fh)        for shnum in range(x):

print("正在读取文件:" str(fl) "的第" str(shnum) "个sheet表的内容...")

rvalue=getFilect(fl,shnum)    #定义最终合并后生成的新文件

endfile='F:/test/excel3.xlsx'

wb1=xlsxwriter.Workbook(endfile)    #创建一个sheet工作对象

ws=wb1.add_worksheet()    for a in range(len(rvalue)):        for b in range(len(rvalue[a])):

c=rvalue[a][b]

ws.write(a,b,c)

wb1.close()

print("文件合并完成")1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162

源文件excel1:

源文件excel2:

运行结果:

合并后的excel3:

python如何根据前两列信息合并多个excel?

通过输出结果可以发现,value被pack之后,转化为了一段二进制字节串,而unpack可以把该字节串再转换回一个元组,但是值得注意的是对于float的精度发生了改变,这是由一些比如操作系统等客观因素所决定的。

打包之后的数据所占用的字节数与C语言中的struct十分相似。

python怎么合并excel的两个sheet并去重?

思路

利用python xlrd包读取excle文件,然后将文件内容存入一个列表中,再利用xlsxwriter将内容写入到一个新的excel文件中。

完整代码

# -*- coding: utf-8 -*-#将多个Excel文件合并成一个import xlrdimport xlsxwriter#打开一个excel文件def open_xls(file):

fh=xlrd.open_workbook(file)    return fh#获取excel中所有的sheet表def getsheet(fh):

return fh.sheets()#获取sheet表的行数def getnrows(fh,sheet):

table=fh.sheets()[sheet]    return table.nrows#读取文件内容并返回行内容def getFilect(file,shnum):

fh=open_xls(file)

table=fh.sheets()[shnum]

num=table.nrows    for row in range(num):

rdata=table.row_values(row)

datavalue.append(rdata)    return datavalue#获取sheet表的个数def getshnum(fh):

x=0

sh=getsheet(fh)    for sheet in sh:

x =1

return xif __name__=='__main__':    #定义要合并的excel文件列表

allxls=['F:/test/excel1.xlsx','F:/test/excel2.xlsx']    #存储所有读取的结果

datavalue=[]    for fl in allxls:

fh=open_xls(fl)

x=getshnum(fh)        for shnum in range(x):

print("正在读取文件:" str(fl) "的第" str(shnum) "个sheet表的内容...")

rvalue=getFilect(fl,shnum)    #定义最终合并后生成的新文件

endfile='F:/test/excel3.xlsx'

wb1=xlsxwriter.Workbook(endfile)    #创建一个sheet工作对象

ws=wb1.add_worksheet()    for a in range(len(rvalue)):        for b in range(len(rvalue[a])):

c=rvalue[a][b]

ws.write(a,b,c)

wb1.close()

print("文件合并完成")1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162

源文件excel1:

源文件excel2:

运行结果:

合并后的excel3:

用python把EXCEL中的几组数据按顺序组合

可以采用一些操作Excel的模块去实现,比如xlrd、xlwt、openpyxl、xlsxwriter等模块。xlrd模块主要用于读取Excel表,xlwt与xlsxwriter模块主要用于将数据写入表中,两个模块任选其一即可,但是xlwt与xlsxwriter模块不支持修改表,所以在信息追加的时候会较麻烦,有些朋友可能这个地方遇到了很大的问题,其实这个问题至少有两种思路解决:

A、换成其他模块,比如openpyxl等,这个模块实现起来会相对简单一些,比如目前已经收到的苏wisdom同学采用的就是这种方法,值得表扬,所以以下方法1会参照苏wisdom同学的答案。此外,截止至目前为止『歹ピ№ㄕ』同学、微雨同学、黄梦颖同学已经提交第二次作业,一并表扬。

B、仍然使用xlwt与xlsxwriter等模块,但是先将每次读取的信息存储到list(列表)中,然后,最后一次写入。这一种方式稍微复杂一些,所以老师在方法2中采用这种方式去写,目的是给大家一个解决方案的参考,有更优的方案可以随时邮箱反馈。

此外,还有一个难点,即一个表格中有多个sheet,我们希望能够用程序自动获取这多个sheet,然后将各sheet中的内容一并写入到最终表格中,目前答案中暂时没有看到解决这个问题,如果大家能解决这个问题,是极好的。各位同学可以参考老师的第二种方法,第二种方式中,考虑了多个sheet的问题,各位也可以对程序进行优化。

用Python导出工程文件两个子页里的数据成为两个exc...

思路

利用python xlrd包读取excle文件,然后将文件内容存入一个列表中,再利用xlsxwriter将内容写入到一个新的excel文件中。

完整代码

# -*- coding: utf-8 -*-#将多个Excel文件合并成一个import xlrdimport xlsxwriter#打开一个excel文件def open_xls(file):

fh=xlrd.open_workbook(file)    return fh#获取excel中所有的sheet表def getsheet(fh):

return fh.sheets()#获取sheet表的行数def getnrows(fh,sheet):

table=fh.sheets()[sheet]    return table.nrows#读取文件内容并返回行内容def getFilect(file,shnum):

fh=open_xls(file)

table=fh.sheets()[shnum]

num=table.nrows    for row in range(num):

rdata=table.row_values(row)

datavalue.append(rdata)    return datavalue#获取sheet表的个数def getshnum(fh):

x=0

sh=getsheet(fh)    for sheet in sh:

x =1

return xif __name__=='__main__':    #定义要合并的excel文件列表

allxls=['F:/test/excel1.xlsx','F:/test/excel2.xlsx']    #存储所有读取的结果

datavalue=[]    for fl in allxls:

fh=open_xls(fl)

x=getshnum(fh)        for shnum in range(x):

print("正在读取文件:" str(fl) "的第" str(shnum) "个sheet表的内容...")

rvalue=getFilect(fl,shnum)    #定义最终合并后生成的新文件

endfile='F:/test/excel3.xlsx'

wb1=xlsxwriter.Workbook(endfile)    #创建一个sheet工作对象

ws=wb1.add_worksheet()    for a in range(len(rvalue)):        for b in range(len(rvalue[a])):

c=rvalue[a][b]

ws.write(a,b,c)

wb1.close()

print("文件合并完成")1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162

源文件excel1:

源文件excel2:

运行结果:

合并后的excel3:

python 批量读取xlsx并合并_python合并多个excel表格数据-python如何读取多个excel合并到一个excel中...相关推荐

  1. Excel表格数据该怎么读取和写入之——xlsread函数和xlswrite函数

    Excel表格数据该怎么读取和写入之--xlsread函数和xlswrite函数 excel作为一种数据处理和管理软件,在使用MATLAB时,经常需要对Excel进行读取和写入数据操作. 新人小白,欢 ...

  2. python查找excel中内容_python excel表格数据-python 如何读取 excel 指定单元格内容

    python 怎么从excel中读取数据 VLOOKUP是函数,给定一个查找的目标,它就能从指定的查找中查找返回想找到的值.它的基本语法为: VLOOKUP(查找目标,查找范围,返回值的列数,精确OR ...

  3. python求excel平均数_#python抓取excel表格数据#使用python3读取处理excel表的数据内容如何对内容求平均值...

    使用python3读取处理excel表的数据内容如何对内容求平均值 先说下概述: 值就是集合平均数. (a1 a2 --an)/n为a1,a2,--,an术平均值. 简单算均数.有这么一组数字10.2 ...

  4. python实现多表格合并_python 如何把两个表格数据,合并为一个呢?

    想把文本 1 和文本 2 ,合并为文本 3 , 2 个数据源, date 是日期,然后另外 2 个不同字段,想合并到一张表中,也就是合并成同一个 json ,求助,有办法吗 文本 1 : [{'aaa ...

  5. python读取excel表格数据

    python操作excel主要用到xlrd和xlwt两个库,xlrd读取表格数据,支持xlsx和xls格式的excel表格:xlwt写入excel表格数据 一.python读取excel表格数据 1. ...

  6. EXCEL表格数据合并

    EXCEL表格数据合并 主要针对同一个excel文件中包含多个sheet,需要将所有的数据进行汇总. 1.表格数据展示: 2.数据合并步骤: 打开excel表格(当前表格或者新建表格均可),选择数据- ...

  7. python3读取excel数据-Python3读取和写入excel表格数据的示例代码

    python操作excel主要用到 xlrd 和 xlwt 这两个库,xlrd读取excel表格数据, 支持 xlsx和xls格式的excel表格 :xlwt写入excel表格数据: 一.python ...

  8. Python3读取和写入excel表格数据

    目录 一.python读取excel表格数据 1.读取excel表格数据常用操作 2.xlrd模块的主要操作 3.读取单元格内容为日期时间的方式 4. 读取合并单元格的数据 二.python写入exc ...

  9. python3 写入excel表格数据_Python3读取和写入excel表格数据

    目录 python操作excel主要用到 xlrd和xlwt 这两个库,xlrd读取excel表格数据, 支持 xlsx和xls格式的excel表格 :xlwt写入excel表格数据: 一.pytho ...

最新文章

  1. python 服务器端_python实现服务器端
  2. Visual Studio 2005 Professional Released
  3. 三点提升关键词排名的写作技巧
  4. 【Linux】一步一步学Linux——whatis命令(14)
  5. canvas做的图片查看器1
  6. 实现值两者之间添加 , 、 | 等字符
  7. NDoc使用简要手册 及中文支持(转)
  8. [转]C# 中的常用正则表达式总结
  9. 《FLEX工程师成长计划》--入门篇之一:关于此书
  10. 什么是java mvc模式_什么是MVC?
  11. 步进电机驱动程序,5线
  12. 用Wireshark抓包分析协议 计算机网络
  13. 详解人工智能(AI) 机器学习(ML) 深度学习(DL)
  14. Java的生成随机数
  15. 什么事,是你当了领导才明白的?
  16. MAC常用快捷键 基本常用的都整理在这里了
  17. 串口编程(VS2010)
  18. IBM小型机AIX操作系统总结03--系统安装
  19. 哈啰出行Java面试
  20. 记录集不支持更新。这可能是提供程序的限制,也可能是选定锁定类型的限制...

热门文章

  1. linux server.xml日志参数,Linux Log4j+Kafka+KafkaLog4jAppender 日志收集
  2. pcb只开窗不镀锡_案例图解射频PCB设计要点
  3. leetcode第 46 场双周赛
  4. redis和mysql数据不一致_高并发下为什么 redis 和数据库不一致?怎么解决?
  5. AcWing之从尾到头打印链表
  6. 赛尔原创 | N-LTP:基于预训练模型的中文自然语言处理平台
  7. 推荐一个快速定位深度学习代码bug的炼丹神器!
  8. Redis系列教程(四):Redis为什么是单线程、及高并发快的3大原因详解
  9. 开源开放 | 开源网络通信行业知识图谱(新华三)
  10. 开源开放 | 疾病科室、心血管系统疾病知识图谱发布,助力电子病历系统建设...