python接口自动化之openpyxl学习

python接口自动化之openpyxl学习

由于接口自动化测试需要用到python的第三方库--openpyxl库,运用openpyxl库可以进行exl的读和写,再结合unittest测试框架,就能进行接口自动化测试。

一:openpyxl库的安装:pip install openpyxl

 

二:查看openpyxl库的属性

import openpyxl
dir1= dir(openpyxl)
print(dir1)

[‘DEFUSEDXML‘, ‘LXML‘, ‘NUMPY‘, ‘PANDAS‘, ‘Workbook‘, ‘__author__‘, ‘__author_email__‘, ‘__builtins__‘, ‘__cached__‘, ‘__doc__‘, ‘__file__‘, ‘__license__‘, ‘__loader__‘, ‘__maintainer_email__‘, ‘__name__‘, ‘__package__‘, ‘__path__‘, ‘__spec__‘, ‘__url__‘, ‘__version__‘, ‘_constants‘, ‘cell‘, ‘chart‘, ‘chartsheet‘, ‘comments‘, ‘compat‘, ‘constants‘, ‘descriptors‘, ‘drawing‘, ‘formatting‘, ‘formula‘, ‘load_workbook‘, ‘packaging‘, ‘pivot‘, ‘reader‘, ‘styles‘, ‘utils‘, ‘workbook‘, ‘worksheet‘, ‘writer‘, ‘xml‘]

openpyxl库有两个常用的模块 workbook:创建excel工作簿   load_workbook:读写excel文件

1、查看workbook模块属性:

from openpyxl import workbook
print(dir(workbook))

包含如下属性值:

[‘Workbook‘, ‘__builtins__‘, ‘__cached__‘, ‘__doc__‘, ‘__file__‘, ‘__loader__‘, ‘__name__‘, ‘__package__‘, ‘__path__‘, ‘__spec__‘, ‘_writer‘, ‘absolute_import‘, ‘child‘, ‘defined_name‘, ‘external_link‘, ‘external_reference‘, ‘function_group‘, ‘properties‘, ‘protection‘, ‘smart_tags‘, ‘views‘, ‘web‘, ‘workbook‘]

2、查看workbook.Workbook的属性

from openpyxl import workbook
print(dir(workbook.Workbook))

包含如下属性值:

[‘__class__‘, ‘__contains__‘, ‘__delattr__‘, ‘__delitem__‘, ‘__dict__‘, ‘__dir__‘, ‘__doc__‘, ‘__eq__‘, ‘__format__‘, ‘__ge__‘, ‘__getattribute__‘, ‘__getitem__‘, ‘__gt__‘, ‘__hash__‘, ‘__init__‘, ‘__init_subclass__‘, ‘__iter__‘, ‘__le__‘, ‘__lt__‘, ‘__module__‘, ‘__ne__‘, ‘__new__‘, ‘__reduce__‘, ‘__reduce_ex__‘, ‘__repr__‘, ‘__setattr__‘, ‘__sizeof__‘, ‘__str__‘, ‘__subclasshook__‘, ‘__weakref__‘, ‘_add_sheet‘, ‘_data_only‘, ‘_read_only‘, ‘_setup_styles‘, ‘active‘, ‘add_named_range‘, ‘add_named_style‘, ‘chartsheets‘, ‘close‘, ‘copy_worksheet‘, ‘create_chartsheet‘, ‘create_named_range‘, ‘create_sheet‘, ‘data_only‘, ‘excel_base_date‘, ‘get_active_sheet‘, ‘get_index‘, ‘get_named_range‘, ‘get_named_ranges‘, ‘get_sheet_by_name‘, ‘get_sheet_names‘, ‘guess_types‘, ‘index‘, ‘mime_type‘, ‘named_styles‘, ‘path‘, ‘read_only‘, ‘remove‘, ‘remove_named_range‘, ‘remove_sheet‘, ‘save‘, ‘sheetnames‘, ‘style_names‘, ‘template‘, ‘worksheets‘, ‘write_only‘]

举例子:

#新建一个excel

Wb=workbook.Workbook() #创建一个excel工作薄

Wb.creat_sheet(lbb)    #创建一个名为lbb的工作表

Wb.save(py15_lbb.xlsx)  # 将工作薄另存为py15_lbb,可以指定特定路径

 

3、查看load_workbook模块属性:

from openpyxl import load_workbook
print(dir(load_workbook))

包含如下属性值:

[‘__annotations__‘, ‘__call__‘, ‘__class__‘, ‘__closure__‘, ‘__code__‘, ‘__defaults__‘, ‘__delattr__‘, ‘__dict__‘, ‘__dir__‘, ‘__doc__‘, ‘__eq__‘, ‘__format__‘, ‘__ge__‘, ‘__get__‘, ‘__getattribute__‘, ‘__globals__‘, ‘__gt__‘, ‘__hash__‘, ‘__init__‘, ‘__init_subclass__‘, ‘__kwdefaults__‘, ‘__le__‘, ‘__lt__‘, ‘__module__‘, ‘__name__‘, ‘__ne__‘, ‘__new__‘, ‘__qualname__‘, ‘__reduce__‘, ‘__reduce_ex__‘, ‘__repr__‘, ‘__setattr__‘, ‘__sizeof__‘, ‘__str__‘, ‘__subclasshook__‘]

举例子:

Excel的读写操作: 结论excel中读取到的数据类型:数字类型还是数字类型,其他类型读取到的都是字符串类型(eval函数转换成python可以识别的数据类型)

wb = load_workbook("py15_lbb.xlsx")  #打开工作薄
sheet = wb["sheet1"]          #定位到表单
value = sheet.cell(1,2)         #读取第1行,第2列的值
sheet.cell(1,2).value = "lemon"  # 更新第1行,第2列的值为lemon
row = sheet.max_row         # 获取该sheet的最大行
column = sheet.max_column   # 获取该sheet的最大列

 

 

 

原文地址:https://www.cnblogs.com/qiyuedetiankong/p/10886561.html

时间: 2024-11-06 20:49:51

python接口自动化之openpyxl学习的相关文章

python接口自动化2-发送post请求

前言 发送post的请求参考例子很简单,实际遇到的情况却是很复杂的,首先第一个post请求肯定是登录了,但登录是最难处理的.登录问题解决了,后面都简单了. 一.查看官方文档 1.学习一个新的模块,其实不用去百度什么的,直接用help函数就能查看相关注释和案例内容. >>import requests >>help(requests) 2.查看python发送get和post请求的案例 >>> import requests       >>> r

2020年第二期《python接口自动化+测试开发》课程,预售!

2020年第二期<python接口自动化+python测试开发>课程,12月15号开学! 主讲老师:上海-悠悠 上课方式:QQ群视频在线教学,方便交流 本期上课时间:12月15号-3月29号,每周六.周日晚上20:30-22:30 报名费:报名费3000一人(周期3个月) 联系QQ:283340479 课表如下 课程主要涉及的内容: 1.fiddler抓包与接口测试(测试基础必备) 2.python+pytest框架实现接口自动化测试(pytest框架甩unittest几条街) 3.httpr

2020年第三期《python接口自动化+测试开发》课程,4月5号开学(火热报名中!)

2020年第三期<python接口自动化+python测试开发>课程,4月5号开学(火热报名中!) 主讲老师:上海-悠悠 上课方式:QQ群视频在线教学,方便交流 本期上课时间:4月5号-6月27号,每周六.周日晚上20:30-22:30 报名费:报名费3000一人(周期3个月) 联系QQ:283340479 课表如下 课程主要涉及的内容: 1.fiddler抓包与接口测试(测试基础必备) 2.python+pytest+allure框架实现接口自动化测试(pytest框架甩unittest几条

python接口自动化9-https请求(SSL)

前言 本来最新的requests库V2.13.0是支持https请求的,但是一般写脚本时候,我们会用抓包工具fiddler,这时候会报:requests.exceptions.SSLError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:590) 小编环境: python:2.7.12 requests:2.13.0 fiddler:v4.6.2.0 一.SSL问题 1.不启用fiddler,直接发htt

python接口自动化5-Json数据处理

前言 有些post的请求参数是json格式的,这个前面第二篇post请求里面提到过,需要导入json模块处理. 一般常见的接口返回数据也是json格式的,我们在做判断时候,往往只需要提取其中几个关键的参数就行,这时候就需要json来解析返回的数据了. 一.json模块简介 1.Json简介:Json,全名 JavaScript Object Notation,是一种轻量级的数据交换格式,常用于http请求中 2.可以用help(json),查看对应的源码注释内容 Encoding basic P

python接口自动化10-token登录

前言 有些登录不是用cookie来验证的,是用token参数来判断是否登录. token传参有两种一种是放在请求头里,本质上是跟cookie是一样的,只是换个单词而已:另外一种是在url请求参数里,这种更直观. 一.登录返回token 1.如下图的这个登录,无cookies 2.但是登录成功后有返回token 二.请求头带token 1.登录成功后继续操作其它页面,发现post请求的请求头,都会带token参数 2.这种请求其实比cookie更简单,直接把登录后的token放到头部就行 三.to

python接口自动化8-参数化

前言 前面一篇实现了参数的关联,那种只是记流水账的完成功能,不便于维护,也没什么可读性,接下来这篇可以把每一个动作写成一个函数,这样更方便了. 参数化的思维只需记住一点:不要写死 一.登录函数 1.s参数是session的一个实例类,先放这里,方便写后面代码 2.登录函数传三个参数,s是需要调用前面的session类,所以必传,可以传个登录的url,然后payload是账号和密码 二.保存草稿 1.编辑内容的标题title和正文body_data参数化了,这样后面可以方便传不同值 2.这里返回了

python接口自动化7-参数关联

前言 我们用自动化发帖之后,要想接着对这篇帖子操作,那就需要用参数关联了,发帖之后会有一个帖子的id,获取到这个id,继续操作传这个帖子id就可以了 一.删除草稿箱 1.我们前面讲过登录后保存草稿箱,那可以继续接着操作:删除刚才保存的草稿 2.用fiddler抓包,抓到删除帖子的请求,从抓包结果可以看出,传的json参数是postId 3.这个postId哪里来的呢?可以看上个请求url地址 4.也就是说保存草稿箱成功之后,重定向一个url地址,里面带有postId这个参数.那接下来我们提取出来

python接口自动化4-绕过验证码登录(cookie)

前言 有些登录的接口会有验证码:短信验证码,图形验证码等,这种登录的话验证码参数可以从后台获取的(或者查数据库最直接). 获取不到也没关系,可以通过添加cookie的方式绕过验证码. 一.抓登录cookie 1.登录后会生成一个已登录状态的cookie,那么只需要直接把这个值添加到cookies里面就可以了. 2.可以先手动登录一次,然后抓取这个cookie,这里就需要用抓包工具fiddler了 3.先打开博客园登录界面,手动输入账号和密码(勾选下次自动登录) 4.打开fiddler抓包工具,刷