python如何对excel操作_python中的excel操作

一. Excel在python中的应用

存测试数据

有的时候大批量的数据,我们需要存到数据库中,在测试的时候才能用到。测试的时候就从数据库中读取出来。这点是非常重要的!

存测试结果

二. Excel中的三大对象:

Workbook

Sheet

Cell

在excel中,主要的操作是在sheet中对数据进行读、写、修改的操作

操作流程:

1. 打开一个excel文件,或者创建一个excel文件,生成一个工作簿(workbook)对象

2. 获取某个表单(sheet)对象

3. 在表单对象中的单元格(cell)中读、写、修改数据

三. Excel库

python中有好几个与excel操作相关的模块

xlrd库:从excel中读取数据,支持xls, xlsx

xlwt库:对excel进行修改操作。不支持对xlsx格式的修改

xlutils库:在xlwt和xlrd中,对一个已存在的文件进行修改

官方说法:

openpyxl is a Python library to read/write Excel 2010 xlsx/xlsm/xltx/xltm files

网址:http://www.python-excel.org/

四. openpyxl--常用操作

from openpyxl import load_workbook

#打开一个已存在的excel文件

wb = load_workbook("sample.xlsx")

from openpyxl import Workbook

#创建一个新的excel文件

wb = Workbook("hello.xlsx")

#获取sheet对象,get_sheet_by_name是旧的方法,新的方法是wb[sheetname]

sh = wb.get_sheet_by_name("Sheet1")

#创建一个新的sheet

sh_new = wb.create_sheet("新建的sheet")

#获取指定单元格中的值

cl = sh.cell(row=1, column=1).value

#修改指定单元格的值

sh.cell(row=1, column=1).value = "hello"

#获取当前sheet的数据总行数

rows = sh.max_row

#获取当前sheet的数据总列数

columns = sh.max_column

#保存当前workbook中所有的修改

wb.save("sample.xlsx")

注意:openpyxl中列和行的起始下标都是1

五. 实例

#引入库

from openpyxl importload_workbook#加载一个excel文件,进入到工作簿

wb = load_workbook("testdata.xlsx")#获取指定的表单

sh = wb["Sheet1"]#获取表单中数据

name = sh.cell(row=2, column=1).valueprint(name)#修改表单中的数据--修改数据,注意在写操作时,必须先关闭excel文件

sh.cell(row=2, column=3).value = 18

#保存修改数据的操作--保存数据

wb.save("testdata.xlsx")#获取总行数、总列数

print(sh.max_row)print(sh.max_column)print(sh.cell(row=3, column=3).value)

sh.cell(row=3, column=3).value = 25

print(sh.cell(row=3, column=3))#读取所有数据,按行读取

for index in range(1, sh.max_row + 1):print("行号:", index)for sub_i in range(1, sh.max_column + 1):print("列号:", sub_i, "内容:", sh.cell(row=index, column=sub_i).value)

结果:

小翟3

3

18

行号:1列号:1内容: name

列号:2内容: sex

列号:3内容: age

行号:2列号:1内容: 小翟

列号:2内容: 男

列号:3 内容: 18行号:3列号:1内容: 瑛子

列号:2内容: 女

列号:3 内容: 25

附excel内容:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值