python自动化——自动化框架常用封装代码复习

日志模块:

import logging
import os


def creat_log(name="mylog", level="DEBUG", filename="log.log", sh_level="DEBUG", fh_level="DEBUG"):
    log = logging.getLogger(name)

    log.setLevel(level)

    fh = logging.FileHandler(filename, encoding="utf-8")
    fh.setLevel(sh_level)
    log.addHandler(fh)

    sh = logging.StreamHandler()
    sh.setLevel("DEBUG")
    log.addHandler(sh)

    formats = "%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s"

    log_format = logging.Formatter(formats)

    fh.setFormatter(log_format)
    sh.setFormatter(log_format)

    return log


my_log = creat_log()

 

其他模块如何引入日志模块:

from hander_log import my_log

my_log.error("hao")
my_log.debug("buhao")

 

 

 

 

 

 

 

 

 

 ========================================================

 

 

 

 

 

 

 

 

 

 

 读取配置文件模块:

 

import os
from configparser import ConfigParser

class ReadConfig(ConfigParser):

    def __init__(self,conf_file):
        super().__init__()

        self.read(conf_file,encoding="utf-8")

conf = ReadConfig(r"D:\project\pythonProject\config.ini")

 

from hander_config import conf

from hander_log import my_log

# my_log.error("hao")
# my_log.debug("buhao")


print(conf.get("data","user"))
print(conf.get("data","password"))

print(conf.get("mysql","password"))
print(conf.getint("mysql","port"))

 

 

 

 

 

 

 

 

 

 

 

 

 

================================================================

 

 

 

 

 

 

 

 

 

 

读取excel中的用例:

 

import openpyxl


class HanderExcel:

    def __init__(self,filename,sheetname):

        self.filename = filename
        self.sheetname = sheetname

    def read_data(self):
        workbook = openpyxl.load_workbook(self.filename)
        sh = workbook[self.sheetname]
        res = list(sh.rows)

        #获取第一行的表头
        title = [i.value for i in res[0]]
        cases = []

        #遍历第一行之外的其他行
        for item in res[1:]:
            data = [i.value for i in item]
            dic = dict(zip(title,data))
            cases.append(dic)


        return cases

 

from hander_config import conf
from hander_log import my_log
from hander_excel import HanderExcel


# my_log.error("hao")
# my_log.debug("buhao")


# print(conf.get("data","user"))
# print(conf.get("data","password"))
#
# print(conf.get("mysql","password"))
# print(conf.getint("mysql","port"))



excel = HanderExcel(r"D:\project\pythonProject\abc.xlsx","SH")
cases = excel.read_data()
print(cases)

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

============================================================================

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

DDT数据驱动:

 

import unittest
# 导入ddt,list_data
from unittestreport import ddt, list_data

# 用例数据
cases = [
    {'expected': {'code': 0, 'msg': '登录成功'}, 'params': {"username": "duanxc", "password": 123456}},
    {'expected': {'code': 1, 'msg': '账号和密码不正确'}, 'params': {"username": "duanxc", "password": 12345}}
]

# 在类前@ddt
@ddt
class test_login(unittest.TestCase):

    # 在方法面前@list_data()括号里面传入用例数据
    @list_data(cases)
    # 方法参数里面,写一个变量去接受cases的数据
    def test_login_01(self, item):
        # 准备用例数据
        data = item["params"]
        expected = item["expected"]
        print(data)
        print("===================")
        print(expected)
        print("+++++++++++++++++++++")

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 ========================================================================

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

数据库封装:

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 =========================================================================

 

 

 

 

 

 

 

 

 

 

 

 

 

 

答疑解惑:

 

 

在您给出的CLanguage类定义中,xsCLanguage类的一个实例。

 

要使得其他模块能够引入xs并调用其方法,您需要在xs对象被创建和初始化后,确保它是可以被其他模块访问的。

 

通常,这意味着您需要把xs放在一个所有模块都可以访问的位置,比如一个全局变量,或者把它作为一个模块级别的对象。

 

这里有一个简单的例子,说明如何在一个模块中创建CLanguage的实例,并在另一个模块中引入和使用它:

 

首先,我们有一个名为clanguage_module.py的模块,它定义了CLanguage类并创建了一个实例xs

python# clanguage_module.py

class CLanguage:
def __init__(self):
self.name = "ninhao"
self.number = 100

def info(self):
print("我正在学 Python")

def fanhui(self):
return self.name

# 创建CLanguage类的实例
xs = CLanguage()

 

 

然后,在另一个模块中,我们可以引入xs并调用它的方法,但需要注意的是,xs必须是一个全局变量,或者通过某种方式(比如函数返回值)暴露给其他模块:

 

 

python# another_module.py

# 引入clanguage_module模块中的xs对象
from clanguage_module import xs

# 调用xs的方法
xs.info() # 输出: 我正在学 Python
print(xs.fanhui()) # 输出: ninhao

 

 

在这个例子中,another_module.py通过from clanguage_module import xs语句引入了xs对象。然后,它就可以像调用普通对象的方法一样调用xs的方法了。

 

然而,通常我们不推荐在模块级别创建类的实例,因为这违反了面向对象编程的封装原则,并且可能导致代码难以测试和维护。

 

更好的做法是在需要的时候在函数或方法中创建类的实例,或者提供一个工厂函数来创建和返回类的实例。

 

这样,其他模块可以通过调用这个工厂函数来获得类的实例,而不是直接访问模块级别的对象。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

=========================================================================

 

 

 

 

 

 

 

 

 

 

 

 

 

PS:

 

 

 

posted @ 2024-03-19 13:54  小白龙白龙马  阅读(43)  评论(0编辑  收藏  举报