1. Python 操作 Excel 的函数库

我主要尝试了 3 种读写 Excel 的方法:

1> xlrd, xlwt, xlutils: 这三个库的好处是不需要其它支持,在任何操作系统上都可以使用。xlrd 可以读取 .xls, .xlsx 文件,非常好用;但因为 xlwt 不能直接修改 Excel 文档,必须得复制一份然后另存为其它文件,而且据说写复杂格式的 Excel 文件会出现问题,所以我没有选它来写 Excel 文件。

2> openpyxl: 这个库也是不需要其它支持的,而且据说对 Office 2007 格式支持得更好。遗憾地是,我经过测试,发现它加载 Excel 文件的效率比 xlrd 慢 3 倍以上,内存使用在 10 倍以上,于是就放弃了。

3> win32com: Python Win32 扩展,这个库需要运行环境为 Windows+Office 对应版本。由于 Python Win32 扩展只是把 COM 接口包装了一下,可以视为与 VBA 完全相同,不会有读写格式上的问题。尝试了一下用 win32com 读取 Excel 文件,效率还是比 xlrd 慢一些。

由于读取效率上 xlrd > win32com > openpyxl,所以我自然选择了 xlrd 用来读取统计报表;而最终输出的报表格式较复杂,所以选择了 win32com 直接操作 Excel 文件。

2. Python 里的关系型数据库

SQLite 是一个非常轻量级的关系型数据库,很多语言和平台都内置 SQLite 支持,也是 iOS 和 Android 上的默认数据库。Python 的标准库里也包含了 sqlite3 库,用起来非常方便。

3. 用 xlrd 读取 Excel 并插入数据库样例

如果数据量不大,直接用 Python 内部数据结构如 dict, list 就够了。但如果读取的几张表数据量都较大,增加个将数据插入数据库的预处理过程就有很大好处。一是避免每次调试都要进行耗时较长的 Excel 文件载入过程;二是能充分利用数据库的索引和 SQL 语句强大功能进行快速数据分析。

#!/usr/bin/python # -*- coding: gbk -*- import xlrd import sqlite3 # 打开数据库文件

device_city_db = sqlite3.connect('device_city.db') cursor = device_city_db.cursor() # 建表

cursor.execute('DROP TABLE IF EXISTS device_city')

cursor.execute('CREATE TABLE device_city (device_id char(16) PRIMARY KEY, city varchar(16))')

# 打开 device 相关输入 Excel 文件

device_workbook = xlrd.open_workbook('输入.xlsx')

device_sheet = device_workbook.sheet_by_name('设备表')

# 逐行读取 device-城市 映射文件,并将指定的列插入数据库 for row in range(1, device_sheet.nrows):

device_id = device_sheet.cell(row, 6).value    if len(device_id) > 16:

device_id = device_id[0:16]    if len(device_id) == 0:        continue

city = device_sheet.cell(row, 10).value    # 避免插入重复记录

cursor.execute('SELECT * FROM device_city WHERE device_id=?', (device_id,))    res = cursor.fetchone()    if res == None:

cursor.execute('INSERT INTO device_city (device_id, city) VALUES (?, ?)',                       (device_id, city))    else:

if res[1] != city:

print '%s, %s, %s, %s' % (device_id, city, res[0], res[1]) device_city_db.commit()

4. 将结果写入 Excel 文件样例

使用 win32com 写入 Excel 的时候要注意,一定要记得退出 Excel,否则下次运行会出错。这需要增加异常处理语句,我这里偷了个懒,出了异常后要手动杀死任务管理器中的 excel 进程。至于 win32com 中类的接口,可以从 MSDN 网站查阅。 import win32com.client as win32 import os

excel = win32.gencache.EnsureDispatch('Excel.Application') excel.Visible = False # 貌似这里只能接受全路径

workbook = excel.Workbooks.Open(os.path.join(os.getcwd(), '输出.xlsx')) month_sheet = workbook.Worksheets(1) # 计算文件中实际有内容的行数

nrows = month_sheet.Range('A65536').End(win32.constants.xlUp).Row # 操作 Excel 单元格的值

for row in range(5, nrows-4):

month_sheet.Cells(row, 1).Value += something # 保存工作簿

workbook.Save() # 退出 Excel

excel.Application.Quit()

python处理excel函数库_Python 操作 Excel 的函数库相关推荐

  1. python excel操作单元格_python 操作excel表格的方法

    说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...

  2. pythonexcel最好得库_Python操作Excel,你觉得哪个库更好呢?

    原博文 2020-09-27 23:54 − 常见库简介 环境配置及可实现操作 1.xlrd xlrd是一个从Excel文件读取数据和格式化信息的库,支持.xls以及.xlsx文件. http://x ...

  3. python做excel表格代码_python - 操作excel表格

    说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...

  4. python excel详解_python操作excel详解

    前提: python操作excel需要使用的模块有xlrd.xlwt.xlutils.对excel进行读.写.更新操作.操作excel时需要先导入这些模块,demo如下: excel-读操作知识点: ...

  5. python操纵excel的方法_python操作Excel的几种方式

    Python对Excel的读写主要有xlrd.xlwt.xlutils.openpyxl.xlsxwriter几种. 首先你的本地要有包文件,安装上面的包文件如下图 1.xlrd主要是用来读取exce ...

  6. python做excel表格代码_python操作excel表格

    我们在写测试用例的时候,是创建一个表格.xlsx,然后把各种条件加到这张表格中去,所以,如何对excel表格操作,是相当重要的一环,那么,接下来,这篇博客就直接教会大家如何通过python去处理平时工 ...

  7. python求三个数平均值_Python操作Excel教程-average函数求平均值

    Python实战:找到\u201CB列\u201D的平均值,\u201C列C\u201D,\u201CD\u201D.这个过程有点麻烦.请仔细看以下步骤:\u201D.1. 核心代码2.操作结果3.流 ...

  8. python读excel字体颜色_python操作excel之设置字体颜色及格式

    原博文 2020-06-03 13:46 − xlwings如何设置字体.颜色等属性 # coding: utf-8 import xlwings as xw app=xw.App(visible=F ...

  9. python 做excel可视化报告_Python操作Excel制作可视化数据图,实现自动化办公

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理. 以下文章来源于IT入门 安装 操作一个简单的Excel文档 操作注释及代码: 操作完成后,数 ...

  10. python调用百度OCR识别证件+操作excel表格

    python调用百度OCR识别证件+操作excel表格 如果要操作文件的话最好让程序知道文件存不存在,因为做了GUI界面,报错不会直接弹出来,异常捕获就用得比较频繁 因为面向对象没学好,GUI是用工具 ...

最新文章

  1. bat递归查找指定文件_dos命令find图文教程,查找搜索文件文本字符串,bat批处理脚本...
  2. 静态移值编译的关键环境变量
  3. js控制Iframe 和 iframe与主页的交互,传值 (转载)
  4. java组件化的优势_组件化编程开发如何判断组件的优劣性
  5. 明天是你的生日~~~
  6. [DLX反复覆盖] hdu 2828 Lamp
  7. Java学习笔记之 IO包 字节流
  8. iview代码片段 去除水平menu底部横线
  9. SpringBoot配置swagger2(亲测有效,如果没有配置成功,欢迎在下方留言)
  10. iPhone 12 或10月13日发布;微信支付正计划加码存款市场;Swift正式登陆Win 10 | 极客头条
  11. CCF201909-5 城市规划【树形DP】(100分题解链接)
  12. Elasticsearch6.3.0环境安装
  13. 289页初中级前端题助你拿下Offer,附面试题答案
  14. FBI也没辙?超强加密软件TrueCrypt全教程
  15. CSDN账号注册 设置用户名
  16. 从零开始学java第一章 认识java
  17. swf游戏保存进度_swf游戏
  18. 使用pandoc 生成带中文的pdf
  19. 51单片机键盘、矩阵键盘松手检测
  20. Android——浙理体育(飞翔的红蜻蜓)反编译分析

热门文章

  1. smith圆图重要性_(完整版)smith史密斯圆图(个人总结),推荐文档
  2. 工业4.0时代,怎样为孩子筹备未来教育?
  3. h5打开小程序的方法 总结
  4. 规范-阿里代码规范设置
  5. iOS逆向(八)逆向工具 otool 介绍
  6. python导入鸢尾花数据集_python鸢尾花数据集的分类问题 -- 逻辑回归问题研究
  7. SAS9.2安装及遇到的问题。安装时提醒Sas安装数据SID文件无效
  8. win10照片查看器_win10最好的看图软件?win10照片查看软件推荐
  9. 川崎机器人signal_阳江Kawasaki机器人控制器维修中心
  10. vnc远程桌面,细数五款使用感超强的vnc远程桌面软件