Python 可以读写 Excel 表格吗?

当然可以。 Python 下有很多类库可以做到, openpyxl 就是其中的佼佼者。

openpyxl 的设计非常漂亮 ,你一定会喜欢它!不信请往下看:

工作簿

开始 openpyxl 前,无需提前建好工作簿( Workbook )。 只需导入 Workbook 类,便可在内存中创建新工作簿并开始操作:

>>> from openpyxl import Workbook
>>> wb = Workbook()

新建的工作簿默认预先建好一个工作表,通过 active 属性即可获取:

>>> ws = wb.active

注解

如果工作簿包含多个工作表,该属性将返回第一个。

通过 create_sheet 方法,可以创建新的工作表。 创建可以是在后面追加:

>>> ws1 = wb.create_sheet('Mysheet')

或者,在前面插入:

>>> ws1 = wb.create_sheet('Mysheet', 0)

未指定表格名将自动生成,序列形如: SheetSheet1Sheet2 ,以此类推。 当然了,你觉得不合适可以进行修改:

>>> ws.title = 'New Title'

工作表标题标签背景颜色默认是白色。 用一个 RGB 颜色代码设置 sheet_properties.tabColor 属性即可修改:

>>> ws.sheet_properties.tabColor = "1072BA"

一旦你给工作表命名,便可以通过该名字来定位:

>>> ws3 = wb["New Title"]

通过 sheetnames 属性,可以取出所有工作表表名:

>>> print(wb.sheetnames)
['Sheet2', 'New Title', 'Sheet1']

当然了,遍历所有工作表,直接 for-in 更为优雅:

>>> for sheet in wb:
... print(sheet.title)

使用 copy_worksheet 方法,可在工作簿内拷贝工作表:

>>> source = wb.active
>>> target = wb.copy_worksheet(source)

从文件加载

如果已有工作簿,可通过 openpyxl.load_workbook 函数进行加载:

>>> from openpyxl import load_workbook
>>> wb2 = load_workbook('test.xlsx')
>>> print(wb2.sheetnames)
['Sheet2', 'New Title', 'Sheet1']

数据处理

单个单元格

操作工作表,从修改单元格内容开始。单元格可以通过工作表键直接访问:

>>> cell = ws['A4']

这个语句将返回 A4 单元格,或者在单元格不存在时创建它。可以直接赋值:

>>> ws['A4'] = 10

另一种方式是使用 cell 方法访问单元格,指定行和列:

>>> cell = ws.cell(row=4, column=2, value=10)

注解

工作表创建后,不包含任何单元格,单元格在第一次被访问时自动创建。

多单元格

连续多个单元格可以通过切片获得:

>>> cell_range = ws['A1':'C2']

切片取得的单元格范围如下:

以行或列为单位也可以:

# 取出 C 列
>>> colC = ws['C'] # 取出 C 至 D 列
>>> col_range = ws['C:D'] # 取出第 10 行
>>> row10 = ws[10] # 取出第 5 至 10 行
>>> row_range = ws[5:10]

使用 iter_rows 方法也可以:

# 从第 1 行开始遍历,直到第 2 行,每行最多返回 3 列
>>> for row in ws.iter_rows(min_row=1, max_row=2, max_col=3):
... for cell in row:
... print(cell)
<Cell Sheet1.A1>
<Cell Sheet1.B1>
<Cell Sheet1.C1>
<Cell Sheet1.A2>
<Cell Sheet1.B2>
<Cell Sheet1.C2>

如需遍历表格所有行或列,可以使用相关属性。使用 rows 属性遍历所有行:

>>> ws = wb.active
>>> ws['C9'] = 'hello world'
>>> tuple(ws.rows)
((<Cell Sheet.A1>, <Cell Sheet.B1>, <Cell Sheet.C1>),
(<Cell Sheet.A2>, <Cell Sheet.B2>, <Cell Sheet.C2>),
(<Cell Sheet.A3>, <Cell Sheet.B3>, <Cell Sheet.C3>),
(<Cell Sheet.A4>, <Cell Sheet.B4>, <Cell Sheet.C4>),
(<Cell Sheet.A5>, <Cell Sheet.B5>, <Cell Sheet.C5>),
(<Cell Sheet.A6>, <Cell Sheet.B6>, <Cell Sheet.C6>),
(<Cell Sheet.A7>, <Cell Sheet.B7>, <Cell Sheet.C7>),
(<Cell Sheet.A8>, <Cell Sheet.B8>, <Cell Sheet.C8>),
(<Cell Sheet.A9>, <Cell Sheet.B9>, <Cell Sheet.C9>))

使用 columns 属性遍历所有列:

>>> tuple(ws.columns)
((<Cell Sheet.A1>,
<Cell Sheet.A2>,
<Cell Sheet.A3>,
<Cell Sheet.A4>,
<Cell Sheet.A5>,
<Cell Sheet.A6>,
...
<Cell Sheet.B7>,
<Cell Sheet.B8>,
<Cell Sheet.B9>),
(<Cell Sheet.C1>,
<Cell Sheet.C2>,
<Cell Sheet.C3>,
<Cell Sheet.C4>,
<Cell Sheet.C5>,
<Cell Sheet.C6>,
<Cell Sheet.C7>,
<Cell Sheet.C8>,
<Cell Sheet.C9>))

数据存储

Excel 表格通过单元格存储数据,直接赋值即可:

>>> cell.value = 'hello, world'
>>> print(cell.value)
'hello, world' >>> cell2.value = 3.14
>>> print(cell2.value)
3.14

与此同时,还可以给单元格附加类型以及格式化信息,创建工作簿时需要指定 guess_types 参数:

>>> wb = Workbook(guess_types=True)

这样一来,文本(包括百分比)将自动转换成浮点数:

>>> cell.value = '31.50'
>>> print(cell.value)
31.5 >>> cell2.value = '12%'
>>> print(cell2.value)
0.12

日期可以直接由原生的 datetime 对象来设置:

>>> import datetime
>>> cell.value = datetime.datetime.now()
>>> print cell.value
datetime.datetime(2010, 9, 10, 22, 25, 18)

保存至文件

最保险的保存方式是调用 save 方法保存到指定文件:

>>> wb = Workbook()
>>> wb.save('balances.xlsx')

警告

这个操作将覆盖已存在的文件,没有任何提示!

借助 template 属性,可以将工作表保存成模板文档:

>>> wb = load_workbook('document.xlsx')
>>> wb.template = True
>>> wb.save('document_template.xltx')

或者保存成普通文档:

>>> wb = load_workbook('document_template.xltx')
>>> wb.template = False
>>> wb.save('document.xlsx', as_template=False)

保存至流

FlaskDjangoWeb 应用,可能需要将文件保存到流( stream )。 借助一个临时文件( NamedTemporaryFile )可以轻松实现:

>>> from tempfile import NamedTemporaryFile
>>> from openpyxl import Workbook
>>> wb = Workbook() # 先保存到临时文件,再将文件内容读出
>>> with NamedTemporaryFile() as tmp:
... wb.save(tmp.name)
... tmp.seek(0)
... stream = tmp.read()

附录

更多 Python 技术文章请访问:Python语言小册

用 Python 读写 Excel 表格的更多相关文章

  1. Python读写Excel表格

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

  2. Python读写Excel表格(简单实用)

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:giao窝里giao首先安装两个库:pip install xlrd. ...

  3. python读写excel表格,4泼水板房

    import shutilimport osfrom openpyxl import load_workbookfrom xlutils.copy import copyimport win32com ...

  4. Python读写EXCEL文件常用方法大全

    前言 python读写excel的方式有很多,不同的模块在读写的讲法上稍有区别,这里我主要介绍几个常用的方式. 用xlrd和xlwt进行excel读写: 用openpyxl进行excel读写: 用pa ...

  5. [转]用Python读写Excel文件

    [转]用Python读写Excel文件   转自:http://www.gocalf.com/blog/python-read-write-excel.html#xlrd-xlwt 虽然天天跟数据打交 ...

  6. python 处理 Excel 表格

    see: http://www.cnblogs.com/sunada2005/p/3193300.html 一.可使用的第三方库 python中处理excel表格,常用的库有xlrd(读excel)表 ...

  7. python读写Excel文件的函数--使用xlrd/xlwt

    python中读取Excel的模块或者说工具有很多,如以下几种: Packages 文档下载 说明 openpyxl Download | Documentation | Bitbucket  The ...

  8. python 对Excel表格的写入

    python对Excel表格写入需要导入xlrd ,和xlutils两个库 from xlrd import open_workbook from xlutils.copy import copy o ...

  9. Python 利用Python操作excel表格之openyxl介绍Part2

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart()    ...

随机推荐

  1. @ResponseBody与@RestController

    @ResponseBody与@RestController的作用与区别 https://blog.csdn.net/xfl4629712/article/details/78528387

  2. [原]livekd使用问题记录

    sysinternal suite中的livekd.exe可谓神器.可以用来观察本地内核的一些状态,当然抓内核dump再合适不过了. 在使用livekd的时候遇到了一些问题,现总结如下: 使用live ...

  3. [原]procexp替换任务管理器

    2019-09-14更新:本文已经在新博客重新整理发布,请各位读者移步. process explorer有个功能是替换任务管理器,它是怎么实现的呢???   windows有个注册表项HKEY_LO ...

  4. 远程关机 (Windows shutdown Windows)

    在某些场景,可使用远程关机控制整个局域网中的所有电脑进行一键关机或重启,便于管理,以提高工作效率. 从远程系统强制关机,首先需要进行一些必要的设置. 1.使用 win + R 打开运行,输入gpedi ...

  5. Work Scheduling(带反悔的贪心)

    https://www.luogu.org/problem/P2949 题目描述 Farmer John has so very many jobs to do! In order to run th ...

  6. PAT甲级——1008 Elevator

    PATA1008 Elevator The highest building in our city has only one elevator. A request list is made up ...

  7. screen小脚本

    # 创建screen,执行命令,最小化screen #!/usr/bin/env bash screen_name1=$"bdapi" # 检查screen是否存在,等于0.表示s ...

  8. CCS|ANSI|中华人民共和国标准化法|国标|ISO|IEC|Ieeexplore|

    国家的标准的有效期,标龄是5年.强制性标准是是指为保障人体的健康.人身.财产安全的标准和法律.行政法规定强制执行的标准,如药品标准.食品卫生标准. CCS:分类法简写图 国际标准,比如美国国家标准AN ...

  9. 关于Java杂项知识总结

    JVM内存结构 JVM在运行时把从操作系统申请到的内存分为若干区域,主要有栈.堆和方法区,方便Java程序使用 堆内存 使用new关键字创建出来的对象都存储在堆内存中 方法区 被加载的类的信息存储在方 ...

  10. 解决2013Lost connection to MySQL server during query错误方法

    在my.ini配置文件 mysqld 节点下添加 max_allowed_packet = 500M 也就是配置MySQL允许的最大数据包大小,上面的500M你可以根据你的项目修改为你自己的值,只要比 ...