软件测试修炼之路 A Tester

Python操作excel文件

2016-08-18
i.itest.ren

0x00

xlrd支持excel2003的文档,格式为.xls.

官网: http://pypi.python.org/pypi/xlrd

openpyxl支持excel2007及以后的版本, 格式为.xlsx

官网:https://openpyxl.readthedocs.io

xlsxlsx 是两种完全不同的格式,其本质的差别相比字面的区别要多很多。xls 的核心结构是复合文档类型的结构,而 xlsx 的核心结构是 XML 类型的结构,采用的是基于XML的压缩方式,使其占用的空间更小。xlsx 中最后一个 x 的意义就在于此。

0x01 xlrd模块

安装

  • 官网下载安装
    • http://pypi.python.org/pypi/xlrd
    • 然后执行 python setup.py install
  • easy_install xlrd
  • pip install xlrd

导入模块: import xlrd

打开excel文件读取数据: data = xlrd.open_workbook('excelFile.xls')

获取一个工作表:

table = data.sheets()[0]          #通过索引顺序获取

table = data.sheet_by_index(0)    #通过索引顺序获取 

table = data.sheet_by_name(u'Sheet1')  #通过名称获取

获取整行和整列的值(数组):

 table.row_values(i)

 table.col_values(i)

获取行数和列数:

nrows = table.nrows

ncols = table.ncols

循环行列表数据:

for i in range(nrows):
	print table.row_values(i)

单元格:

cell_A1 = table.cell(0,0).value
 
cell_C4 = table.cell(2,3).value

使用行列索引:

cell_A1 = table.row(0)[0].value
 
cell_A2 = table.col(1)[0].value

简单的写入:

row = 0
 
col = 0
 
//类型 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error

ctype = 1 value = '单元格的值'
 
xf = 0 # 扩展的格式化
 
table.put_cell(row, col, ctype, value, xf)
 
table.cell(0,0)  #单元格的值'
 
table.cell(0,0).value #单元格的值'

0x01 Sample code

#coding=utf-8

from openpyxl import Workbook
import datetime

wb = Workbook()
ws = wb.active
ws['A1'] = 42
ws.append([1, 2, 3])
ws['A2'] = datetime.datetime.now()
wb.save('sample.xlsx')

sample.xlsx结果:

42		
2016-08-18 20:47:13	2	3

0x02 创建workbook

创建一个Workbook:

from openpyxl import Workbook
wb = Workbook()

要想使用它,就用openpyxl.workbook.Workbook.active()

ws = wb.active

使用openpyxl.workbook.Workbook.create_sheet()创建一个新的sheet页:

ws1 = wb.create_sheet("Mysheet") # insert at the end (default)
# or
ws2 = wb.create_sheet("Mysheet", 0) # insert at first position

修改sheet页的名称:

ws.title = "New Title"

修改sheet页的背景色:

ws.sheet_properties.tabColor = "1072BA"

Once you gave a worksheet a name, you can get it as a key of the workbook:

ws3 = wb["New Title"]

openpyxl.workbook.Workbook.sheetnames()检查所有worksheet的名称:

print(wb.sheetnames)
返回列表:
['Sheet2', 'New Title', 'Sheet1']

循环输出sheet名称:
for sheet in wb:
	print(sheet.title)

创建一个副本:

source = wb.active
target = wb.copy_worksheet(source)
# 只能复制表格和其风格,不能在工作簿中复制sheet页。

0x03 存取单个表格数据

A4的值直接赋值给变量c

c = ws['A4']

4直接赋给A4

ws['A4'] = 4

用行列标记给赋值openpyxl.worksheet.Worksheet.cell()

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

openpyxl

Excel数据的类型及组织方式

openpyxl中定义了多种数据格式,我只涉及到了其中最重要的三种:

  • NULL: 空值,对应于python中的None,表示这个cell里面没有数据。
  • numberic: 数字型,统一按照浮点数来进行处理。对应于python中的float。
  • string: 字符串型,对应于python中的unicode。

每一个Excel数据文件从上至下分为三个层级的对象:

  • workbook: 每一个Excel文件就是一个workbook。
  • sheet: 每一个workbook中可以包含多个sheet,具体就对应Excel中我们在左下脚所看到的“sheet1”,“sheet2”等。
  • cell: 每一个sheet就是我们通常所看到的一个表格,可以含有m行,n列,每个确定的行号,列号所对应的一个格子就是一个cell。

从excel读取数据

打开workbook

from openpyxl import load_workbook
wb = load_workbook('file_name.xlsx')

打开所需的sheet

ws = wb.get_active_sheet()	//打开workbook中的第一个sheet

ws = wb.get_sheet_by_name("sheet_name")	//通过sheet的名称来获取sheet

//openpyxl似乎没有提供按索引来读取sheet,不过我们总是能很容易地通过sheet_name来实现
sheet_names = wb.get_sheet_names()
ws = wb.get_sheet_by_name(sheet_names[index])

获取对应cell的值:

//按照Excel的习惯用字母来代表列号
c = ws.cell('A4').value
//按照行号列号来读取
d = ws.cell(row = 3, column = 0)

将数据写入到excel

新建workbook

wb = Workbook()

新建sheet

ws1 = wb.create_sheet()  # insert at the end
ws2 = wb.create_sheet(0)  # insert at the first position

写入数据:

直接将要写入的数据赋值给相应的cell即可,若仅仅是修改一个表。可以跳过前两个步骤,不过要注意不要覆盖掉其它数据:

ws.cell('B5') = value1
ws.cell(row = 3, column = 7) = value2

保存数据:

wb.save('file_name.xlsx')

下一篇 Beautiful Soup4

Comments