python接口自动化测试 - configparser配置文件解析器详细使用

configparser简介

  • ConfigParser模块已在Python 3中重命名为configparser
  • 该模块定义了ConfigParser类。 ConfigParser类实现一种基本的配置文件解析器语言,该语言提供的结构类似于 .ini 文件中的结构

ini文件相关知识

  • 键值对可用 = 或者 : 进行分隔
  • section 的名字是区分大小写的,而 option 的名字是不区分大小写的
  • 键值对中头部和尾部的空白符会被去掉
  • 值可以为多行
  • 配置文件可以包含注释,注释以 # 或者 ; 为前缀

ini文件示例

[server]
age = 45
username = yes

# server就是section
# age、username就是option

操作ini文件

认准三部曲

  1. 实例化ConfigParser类
  2. 读取配置文件
  3. 操作配置文件

基础代码

 1     import configparser
 2
 3     filename = ‘F:/Interface/config/server.ini‘
 4     # 实例化configparser
 5     config = configparser.ConfigParser()
 6
 7     # 读取配置文件
 8     config.read(filename, encoding="utf-8-sig")
 9
10     # 获取某个option的值(最常见的操作)
11     config.get(section="server", option="username")

包含知识点

  • 当你配置文件有中文时,在调用 read() 方法时,需要传  encoding="utf-8-sig" 参数
  • 最常见的操作就是 get(section,option,fallback="默认值") ,获取某个option的值,当然也可以传个 fallback ,当你的option不存在的时候,就会返回fallback的值

configparser封装类

为了更好的复用configparser,我们将常用的方法写成一个封装类

 1 #!/usr/bin/env python
 2 # -*- coding: utf-8 -*-
 3
 4 """
 5 __title__  = 操作配置文件工具类
 6 """
 7
 8 import configparser
 9
10
11 class ConfigUtil:
12     # 实例化configparser
13     config = configparser.ConfigParser()
14
15     def read(self, filename):
16         """
17         读取配置文件
18         :param filename: 配置文件路径
19         """
20         self.config.read(filename, encoding="utf-8-sig")
21
22     def get(self, _options, _section=‘server‘):
23         """
24         获取某个options值
25         :param _options: option
26         :param _section: section
27         """
28         try:
29             # 方式一:调用方法
30             value = self.config.get(section=_section, option=_options, fallback="默认值,key不存在则返回此值")
31
32             # 方式二:索引
33             value = self.config[_section][_options]
34         except Exception as e:
35             print("没有获取到值")
36             value = None
37         return value
38
39     def get_options_key_value(self, _section):
40         """
41         以列表(name,value)的形式返回section中的每个值
42         :param _section: 某个section
43         :return: list[tuple(key,value)]
44         """
45         return self.config.items(_section)
46
47     def get_all_section(self):
48         """
49         获取所有section
50         """
51         return self.config.sections()
52
53     def get_options_by_section(self, _section):
54         """
55         获取section下所有可用options
56         """
57         # 方式一
58         keys = []
59         for _options in self.config[_section]:
60             keys.append(_options)
61
62         # 方式二(推荐)
63         keys = self.config.options(_section)
64         return keys
65
66     def assert_section_in_config(self, _section):
67         """
68         判断section是否存在
69         :param _section: 需要判断的section
70         """
71         return _section in self.config
72
73     def assert_options_in_section(self, _section, _options):
74         """
75         判断options是否存在某个section中
76         :param _section: 某个section
77         :param _options: 需要判断的options的key值
78         """
79         return _options in self.config[_section]
80
81
82 configUtil = ConfigUtil()
83
84 if __name__ == ‘__main__‘:
85     filename = ‘F:/imocInterface/config/server.ini‘
86     configUtil.read(filename)
87     print(configUtil.get("username"))
88     print(configUtil.get_all_section())
89     print(configUtil.assert_section_in_config("server"))
90     print(configUtil.get_options_by_section("server"))
91     print(configUtil.assert_options_in_section("server", "usernsame"))
92     print(configUtil.get_options_key_value("server"))

原文地址:https://www.cnblogs.com/poloyy/p/12244936.html

时间: 2024-08-11 07:49:37

python接口自动化测试 - configparser配置文件解析器详细使用的相关文章

python标准库configparser配置解析器

1 >>> from configparser import ConfigParser, ExtendedInterpolation 2 >>> parser = ConfigParser(interpolation=ExtendedInterpolation()) 3 >>> # the default BasicInterpolation could be used as well 4 >>> parser.read_string

Python接口自动化测试框架实战 从设计到开发

第1章 课程介绍(不要错过)本章主要讲解课程的详细安排.课程学习要求.课程面向用户等,让大家很直观的对课程有整体认知! 第2章 接口测试工具Fiddler的运用本章重点讲解如何抓app\web的http\https请求包.如何模拟请求数据.过滤规则及修改响应数据.如何解决无法抓包问题        以及fiddler接口测试,让大家能应用好工具! 第3章 Requests常见方法实战运用本章重点讲解 get\post请求测试.接口测试中结果处理.上传\下载文件接口测试.请求中header及coo

golang开发:类库篇(四)配置文件解析器goconfig的使用

为什么要使用goconfig解析配置文件 目前各语言框架对配置文件书写基本都差不多,基本都是首先配置一些基础变量,基本变量里面有环境的配置,然后通过环境变量去获取该环境下的变量.例如,生产环境跟测试环境使用同一份配置,但是相应的环境下的变量的值是不一样的,通过环境获其取对应的的key value.没明白没关系,举例子的时候就明白了. PHP的框架yaf.golang的框架beego.对配置的书写和解析基本都是一致的. 看下goconfig的解释 goconfig 是一个易于使用,支持注释的 Go

Go语言配置文件解析器,类似于Windows下的INI文件.

config Package config is a Configuration file parser for INI format 包 config 是一个简洁方的,支持注释的Go语言配置文件解析器,类似于Windows下的INI文件. 配置文件形式为[section] 的段构成, 内部使用 name=value键值对 如果为指定段节点,则默认放入名为[default]的段当中. "#"为注释的开头,可以放置于任意的单独一行中. 安装 go get github.com/lxmgo

parseConf(配置文件解析器)

1 /****************************************************************************** 2 * 3 * parseConf(配置文件解析器) 4 * 5 * 1. 很多时候,我们安装一些软件,都可以通过改一些软件的配置文件来修改程序的 6 * 运行性能,如Tomcat修改端口号,访问数据库时一些固定的参数等等; 7 * 2. 本Demo就是干着这么一件事,从properties.conf文件中取出键值对(keyvalue

颠覆你的Python接口自动化测试,约吗?

课程 一直以来,我都很喜欢收集大家问的比较多的问题,然后一边回答一边整理成文.今天也不例外,只是由一问一答,变成了三问三答. [你问] 我们为什么要做接口测试? [我答] 之前在<测试路上你问我答>系列里写过一篇答疑,详见<接口测试的是什么和为什么?> [你问] Python 语言现在为什么这么火? [我答] 这个问题,其实我的回答未必全面,大家在简书或者任何一个技术论坛搜索一下,很多阐述.推荐下面这篇:Python 为何能坐稳 AI 时代头牌语言? [你问] 老师,我之前看了你写

python接口自动化测试

之前在项目中搞了一套jmeter +jenkins + git + ant接口自动化测试框架,在项目中运行了大半年了,效果还不错, 最近搞了一套requests + unittest + ddt +pymysql + BeautifulReport的接口自动化测试框架, 测试用例在yaml文件中, 支持数据驱动.连数据库查询. 目前框架还不是特别完善,需要在后续的使用中一步步优化,目前尚未使用jenkins做集成, 后续结合jenkins做成持续集成.接口自动化测试框架地址:https://gi

Python爬虫(十四)_BeautifulSoup4 解析器

CSS选择器:BeautifulSoup4 和lxml一样,Beautiful Soup也是一个HTML/XML的解析器,主要的功能也是如何解析和提取HTML/XML数据. lxml只会局部遍历,而Beautiful Soup是基于HTML DOM的,会载入整个文档,解析整个DOM树,因此时间和内存开销都会大很多,所以性能要低于lxml. BeautifulSoup用来解析HTML比较简单,API非常人性化,支持CSS选择器.Python标准库中的HTML解析器,也支持lxml的XML解析器.

python接口自动化测试五:爬虫

安装:beautifulsoup4 from bs4 import BeautifulSoup yoyo = open('yoyo.html', 'r')   # 以读的方式打开"yoyo.html"文件 # print(yoyo.read())      # 此方法打开的是一个字符串,内容没有层级结构 # yoyo.close() soup = BeautifulSoup(yoyo, 'html.parser')   # 此时打印出来的效果与.read的一致 # print(soup