分享

在python中使用openpyxl和xlrd创建一个新Excel并把原表格数据复制到新表中

 rcylbx 2019-09-13

在Python中使用openpyxl和xlrd创建一个新Excel并把原表格数据复制到新表中

新的开始

文科出生,经济学专业,年近四旬,纯粹是把这个当成一个兴趣在学。很早之前就打算学Python,但是一直停留在安装好Python,这几天比较空闲,开始从最最基础自学,期间遇到很多坑,不少是靠CSDN的学习笔记填上的,所以也在这里开一个,完整记录一个0基础小白的学习历程,也希望能对后来者有一点帮助。
由于工作的关系,与Excel打交道比较多,所以就从Python与Excel的结合开始吧。

import xlrdimport openpyxl#import不可以大写,xlwt只能解决xls,xlsx需要用openpyxl,安装代码:CMD下,不需#进入python安装直接使用pip3 install xlrd/openpyxl#安装完,如果在CMD里可以import,但在pycharm里面不行且提示ModuleNotFoundError: #No module named 'xlrd',则需要到Setting - Project Interpreter里面选择,点#下拉菜单,看看哪个带着你刚安装的模块,就选哪个。source_xls = [(r'c:\1\1.xlsx'),(r'c:\1\2.xlsx')]#罗列出所有需要被复制的工作簿#这个是别人的代码我复制过来,我猜这里的r代表路径,最后的save也证实了我的猜测data = []#[]代表的是空的可变list,这个表示把data设为一个空的可变listfor i in source_xls: wb = xlrd.open_workbook(i) for sheet in wb.sheets(): for rownum in range(sheet.nrows): data.append(sheet.row_values(rownum))#.append代表在原有数列的最后,插入括号中的数据#i代表两个不同的工作簿#这里有的属性用'.',有的属性用'_',根据我自己的猜测,应该是动作,比如open用','#如果是本身的属性,比如sheet之类,就用'_'#这里推荐用Pycharm来写代码,毕竟对新手而言,界面毕竟友好,也有一些提示wk = openpyxl.Workbook()#创建一个新的表格,这里要注意,Workbook里的W一定要大写,我开始用的是小写,总显示#错误,在这里花了好久找问题wkts = wk.active#在创建工作簿的时候,会创建一个默认的工作表sheet,这里表示使用当前的活跃工作表#如果不想用默认的工作表,代码为 wkts=wk.create_sheet('sheet_name')for i in range(len(data)): for j in range(len(data[i])): wkts.cell(i+1,j+1,data[i][j])wk.save(r'c:\1\Excel_name.xlsx')# 为什么要用i+1 和 j+1呢?因为对range来说,默认是0开始的,也就是第一个数字是0,#而cell()这个函数,他的行和列必须是个至少为1的整数,所以要用+1#有人会问,那我在range的时候,就用range(1,len(data))行不行呢?#答案是不行,因为这样就等于少了0行代表的那部分数据,通常是标题不见了#最后save()函数,前面也要加r,才能显示路径,否则会把引号里所有的都认为是文件名

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多