最近在做一些数据处理和计算的工作,因为数据是以.csv格式保存的,因此刚开始直接用Excel来处理。但是做着做着发现重复的劳动其实并没有多大的意义,于是就想着写个小工具帮着处理。

以前正好在一本书上看到过使用Python来处理Excel表格,可惜没有仔细看。于是我到处查找资料,基本解决了日常所需,终于算是完成了任务,因此撰写此文就算是总结吧,主要记录使用过程的常见问题及解决。

python操作excel主要用到xlrd和xlwt这两个库,即xlrd是读excel,xlwt是写excel的库。可从这里下载https://pypi.python.org/pypi。下面分别记录python读和写excel。

点击免费领取《CSDN大礼包》:

最新全套【Python入门到进阶资料 & 实战源码 & 安装工具】

https://mp.weixin.qq.com/s/9IuSexhanYZ1TMAF1MZIhw

## 1、Python写excel——xlwt

Python写excel的难点不在构造一个workbook的本身,而是填充的数据,不过这不在范围内。在写excel的操作中也有棘手的问题,比如写入合并的单元格就是比较麻烦的,另外写入还有不同的样式。

详细代码如下:

import xlwt#设置表格样式
def set_style(name,height,bold=False):style = xlwt.XFStyle()font = xlwt.Font()font.name = namefont.bold = boldfont.color_index = 4font.height = heightstyle.font = fontreturn style#写Excel
def write_excel():f = xlwt.Workbook()sheet1 = f.add_sheet('学生',cell_overwrite_ok=True)row0 = ["姓名","年龄","出生日期","爱好"]colum0 = ["张三","李四","恋习Python","小明","小红","无名"]#写第一行for i in range(0,len(row0)):sheet1.write(0,i,row0[i],set_style('Times New Roman',220,True))#写第一列for i in range(0,len(colum0)):sheet1.write(i+1,0,colum0[i],set_style('Times New Roman',220,True))sheet1.write(1,3,'2006/12/12')sheet1.write_merge(6,6,1,3,'未知')#合并行单元格sheet1.write_merge(1,2,3,3,'打游戏')#合并列单元格sheet1.write_merge(4,5,3,3,'打篮球')f.save('test.xls')if __name__ == '__main__':write_excel()

结果图:

在此,对write_merge()的用法稍作解释,如上述:sheet1.write_merge(1,2,3,3,‘打游戏’),即在四列合并第2,3列,合并后的单元格内容为"合计",并设置了style。其中,里面所有的参数都是以0开始计算的。

2、Python读excel——xlrd

Python读取Excel表格,相比xlwt来说,xlrd提供的接口比较多,但过程也有几个比较麻烦的问题,比如读取日期、读合并单元格内容。

下面先看看基本的操作:

整体思路为,打开文件,选定表格,读取行列内容,读取表格内数据

详细代码如下:

import xlrd
from datetime import date,datetimefile = ‘test3.xlsx’def read_excel():
wb = xlrd.open_workbook(filename=file)#打开文件
print(wb.sheet_names())#获取所有表格名字sheet1 = wb.sheet_by_index(0)#通过索引获取表格
sheet2 = wb.sheet_by_name('年级')#通过名字获取表格
print(sheet1,sheet2)
print(sheet1.name,sheet1.nrows,sheet1.ncols)rows = sheet1.row_values(2)#获取行内容
cols = sheet1.col_values(3)#获取列内容print(rows)
print(cols)print(sheet1.cell(1,0).value)#获取表格里的内容,三种方式
print(sheet1.cell_value(1,0))
print(sheet1.row(1)[0].value)

运行结果如下:

那么问题来了,上面的运行结果中红框框中的字段明明是出生日期,可显示的确实浮点数;同时合并单元格里面应该是有内容的,结果不能为空。

别急,我们来一一解决这两个问题:

1、python读取excel中单元格内容为日期的方式

python读取excel中单元格的内容返回的有5种类型,即上面例子中的ctype:

ctype : 0 empty,1 string,2 number, 3 date,4 boolean,5 error

即date的ctype=3,这时需要使用xlrd的xldate_as_tuple来处理为date格式,先判断表格的ctype=3时xldate才能开始操作。

详细代码如下:

import xlrdfrom datetime import date,datetimeprint(sheet1.cell(1,2).ctype)date_value = xlrd.xldate_as_tuple(sheet1.cell_value(1,2),wb.datemode)print(date_value)print(date(*date_value[:3]))print(date(*date_value[:3]).strftime('%Y/%m/%d'))

运行结果如下:

2、获取合并单元格的内容

在操作之前,先介绍一下merged_cells()用法,merged_cells返回的这四个参数的含义是:(row,row_range,col,col_range),其中[row,row_range)包括row,不包括row_range,col也是一样,即(1, 3, 4, 5)的含义是:第1到2行(不包括3)合并,(7, 8, 2, 5)的含义是:第2到4列合并。

详细代码如下:

print(sheet1.merged_cells)
print(sheet1.cell_value(1,3))
print(sheet1.cell_value(4,3))
print(sheet1.cell_value(6,1))

运行结果如下:


发现规律了没?是的,获取merge_cells返回的row和col低位的索引即可! 于是可以这样批量获取:

详细代码如下:

merge = []
print(sheet1.merged_cells)
for (rlow,rhigh,clow,chigh) in sheet1.merged_cells:merge.append([rlow,clow])
for index in merge:print(sheet1.cell_value(index[0],index[1]))

运行结果跟上图一样,如下:


Python读写Excel表格,就是这么简单粗暴又好用,如果觉得不错,对你工作中有帮助,动动手指分享给更多人哦。

最后关于Python技术储备

学好 Python 不论是就业、副业赚钱、还是提升学习、工作效率,都是非常不错的选择,但要学会 Python 还是要有一个学习规划。最后,我整理了一份Python全套学习资料,包含视频、源码、课件,给那些想学习 Python 的小伙伴们一点帮助!

① Python所有方向的学习路线图,清楚各个方向要学什么东西
② 100多节Python课程视频,涵盖必备基础、爬虫和数据分析
③ 100多个Python实战案例,学习不再是只会理论
④ 华为出品独家Python漫画教程,手机也能学习
⑤ 历年互联网企业Python面试真题,复习时非常方便

上述这份完整版的Python全套学习资料已经上传CSDN官方,朋友们如果需要可以点击下方链接费获取【保证100%免费】

点击免费领取《CSDN大礼包》:

最新全套【Python入门到进阶资料 & 实战源码 & 安装工具】

https://mp.weixin.qq.com/s/9IuSexhanYZ1TMAF1MZIhw

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

二、学习软件

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、全套PDF电子书

书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。

四、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

五、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

六、清华编程大佬出品《漫画看学Python》

用通俗易懂的漫画,来教你学习Python,让你更容易记住,并且不会枯燥乏味。

七、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

这份完整版的Python全套学习资料已经上传至CSDN官方,朋友们如果需要可以点击下方链接费获取【保证100%免费】

以上全套资料已经为大家打包准备好了,希望对正在学习Python的你有所帮助!

Python读写Excel表格,就是这么简单粗暴又好用(文末免费送资料)相关推荐

  1. python进阶免费-【Python进阶,一学就会】系列1(文末免费送10本书)

    请标星公众号,第一时间获取最新资讯 本期作者:Ravindra Parmar 本期编辑:Dotton | 公众号翻译部成员 ↓↓年度巨献↓↓ ↑↑点我↑↑ 送书活动在文末 本系列,我们将会对Pytho ...

  2. 使用python用什么软件-Python读写Excel表格,就是这么简单粗暴又好用

    Python读写Excel表格,就是这么简单粗暴又好用 2019-04-18 13:45:31 11点赞 107收藏 1评论 最近在做一些数据处理和计算的工作,因为数据是以.csv格式保存的,因此刚开 ...

  3. Python读写Excel表格,就是这么简单粗暴又好用

    python操作excel主要用到xlrd和xlwt这两个库,即xlrd是读excel,xlwt是写excel的库 Python写excel--xlwt Python写excel的难点不在构造一个wo ...

  4. python读取excel表格-python读写Excel表格的实例代码(简单实用)

    安装两个库:pip install xlrd.pip install xlwt 1.python读excel--xlrd 2.python写excel--xlwt 1.读excel数据,包括日期等数据 ...

  5. python简单代码编写-python读写Excel表格的实例代码(简单实用)

    安装两个库:pip install xlrd.pip install xlwt 1.python读excel――xlrd 2.python写excel――xlwt 1.读excel数据,包括日期等数据 ...

  6. 超实用的python技巧:python读写Excel表格的实例代码(简单实用)

    @本文来源于公众号:csdn2299,喜欢可以关注公众号 程序员学府 这篇文章主要介绍了python读写Excel表格的方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可 ...

  7. python读写excel表格

    3中模块3中方式:https://www.jianshu.com/p/19219542bf23 python读写excel的方式有很多,不同的模块在读写的讲法上稍有区别: 用xlrd和xlwt进行ex ...

  8. 用 Python 读写 Excel 表格,就是这么的简单粗暴且乏味

    过去,在很多金融.市场.行政的招聘中,面试官都会问一句:"你精通 EXCEL 吗?" 但今天,他们可能更喜欢问:"你会 Python 吗?" 越来越多的企业开始 ...

  9. python读写excel表格_Python读写Excel表格(简单实用)

    首先安装两个库:pip install xlrd.pip install xlwt! 1.python读excel--xlrd2.python写excel--xlwt 1.读excel数据,包括日期等 ...

最新文章

  1. js long类型精度丢失_浮点数丢失精度
  2. Floyd-Warshall算法
  3. 207-Course Schedule
  4. 剑指Offer--数值的整数次方
  5. 【Java必备资料包】
  6. 计算机网络 chapter3数据链路层
  7. 杭电4515小Q系列故事——世界上最遥远的距离
  8. Tomcat漏洞修复方法【补丁下载及安装详细流程】
  9. 【HDOJ6992】Lawn of the Dead(线段树×, 模拟大法好√)
  10. python多线程调用携程_《Python》线程池、携程
  11. EasyCamera--更简单更灵活的相机应用编写
  12. 在PGConf.Asia-主论坛,纵览腾讯云PostgreSQL技术演进
  13. HCNE复习参考(上)
  14. winhex添加删除字节
  15. Android 显示软键盘输入法和强制隐藏软键盘输入法
  16. C#高斯平滑算法 :二维高斯卷积代码实例
  17. 关于小米路由r3g,TTL刷openwrt救砖几个坑
  18. 小米笔记本第一排按键功能失灵 [ 解决办法 ]
  19. android 三星调用拍照功能吗,玩转Galaxy S3拍照功能全解析
  20. unity新动画系统之动画层和动画遮罩

热门文章

  1. springboot新建webapp
  2. 农村生活污水处理如何因地制宜?
  3. python3 value counts函数_如何使用value_counts()返回的值进行进一步的计算?
  4. Pandas小白入门原理解释(一)---将value_counts的结果转为DataFrame
  5. 【RDMA】RDMA 编程实例(rdma_cm API)
  6. 判断http请求来自手机还是pc
  7. WINDOWS系统简介
  8. 《小学生都能看懂的群论从入门到升天教程》 《群论全家桶》
  9. 让每一个国人去思考,21世纪是不是中国人的世纪?
  10. 使用 技术可以把复杂的计算机网络简化,计算机网络试题及答案