python+Appium自动化:日志logging模块

日志级别

debug、info、warn、error、critical五个级别

logging模块构成(四部分)

logger(记录器,用于日志采集)

Handler(处理器,将日志记录发送到合适的路径)

Filter(过滤器,提供了更好的粒度控制,决定输出哪些日志记录)

Formatter(格式化起,指明了日志的格式)

logger(记录器)

在使用debug、info、warn、error、critical五个级别之前创建logging实例

方法:basicConfig()为日志记录系统做基础配置

# -*- coding: utf-8 -*-#

import logging# 根据日志级别输出# logging.basicConfig(level=logging.INFO)logging.basicConfig(level=logging.CRITICAL)

logging.debug("debug info")logging.info("hello world")logging.warning("warnning info")logging.error("error info")logging.critical("critical info")

Handler(处理器)

1.StreamHandler

将日志记录输出发送到sys.stdout,sys.stderr货值任何类似文件流的对象,上面的例子就是输出到控制台

2.FileHandler

将日志记录输出发送到磁盘文件,继承了StreamHandler的输出功能

logging.basicConfig(filename="runlog.log",lever=logging.DEBUG)

运行后当前脚本路径会生成一个runlog.log文件,用于记录日志

3.NullHandler

不做任何格式化或输出,本质是一个开发人员使用“无操作”处理程序。

Filter(过滤器)

可以使用Filters来完成比级别更加复杂的过滤

Formatter

使用Formatter对象设置日志信息最后的规则、结构和内容,默认的时间为%Y-%m-%d %H%M%S

%(levelno)s                       打印日志级别数值

%(levelname)s                   打印日志级别名称

%(pathname)s                   打印当前执行程序路径

%(filename)s                      打印当前执行程序名称

%(funcName)s                    打印日志当前函数

%(lineno)d                          打印日志当前行号

%(asctime)s                        打印日志时间

%(thread)d                          打印线程id

%(threadName)s                 打印线程名称

%(process)s                        打印进程ID

%(message)s                       打印日志信息

方法:

logging.basicConfig(level=logging.DEBUG,filename="runlog.log",format="%(asctime)s%(filename)s[line:%(lineno)d] %(levelname)s %(message)s")

打开淘宝实例:

# -*- coding: utf-8 -*-#

from appium import webdriver
import yaml
import logging
from selenium.common.exceptions import NoSuchElementException

file = open(‘../xxx.yaml‘,encoding="utf-8")
data = yaml.load(file,yaml.FullLoader)

logging.basicConfig(level=logging.DEBUG,filename="runlog.log",format="%(asctime)s%(filename)s [line:%(lineno)d] %(levelname)s %(message)s")

desired_caps={
               "platformName": data["platformName"],
               "platformVersion": data["platformVersion"],
               "deviceName": data["deviceName"],
               "appPackage": data["appPackage"],
               "appActivity": data["appActivity"],
               "unicodeKeyboard":data["unicodeKeyboard"],
               "resetKeyboard":data["resetKeyboard"],
               "noReset": data["noReset"]
                }
logging.info("logging app...")
driver = webdriver.Remote(‘http://‘+str(data[‘ip‘])+‘:‘+str(data[‘port‘])+‘/wd/hub‘,desired_caps)

#检测同意协议弹窗
def check_agreebtn():
    logging.info("check_agreebtn")
    try:
        agreebtn=driver.find_element_by_id(‘com.taobao.taobao:id/provision_positive_button‘)
    except NoSuchElementException:
        logging.info("no agreebtn")
    else:
        agreebtn.click()

def check_localtionbtn():
    logging.info("check_localtionbtn")
    try:
        localtionbtn=driver.find_element_by_id(‘com.taobao.taobao:id/uik_mdButtonDefaultPositive‘)
    except NoSuchElementException:
        logging.info("no localtionbtn")
    else:
        localtionbtn.click()

check_agreebtn()
check_localtionbtn()

原文地址:https://www.cnblogs.com/bugbreak/p/12085045.html

时间: 2024-10-01 05:27:17

python+Appium自动化:日志logging模块的相关文章

python 的日志logging模块介绍

最近在写使用python生成App的程序,发现直接用print打印信息不太方便和规范,所以使用了logging日志模块,简单记录下用法,正式项目中应该使用logging.config配置日志,可以实现类似log4j的日志文件大小限制,格式控制,输出位置等. 1.简单的将日志打印到屏幕 import logging logging.debug('This is debug message') logging.info('This is info message') logging.warning(

Python进阶(十一)----包,logging模块

Python进阶(十一)----包,logging模块 一丶包的使用 什么是包: ? 包是通过使用 .模块名的方式组织python模块名称空间的方式. 通俗来说,含有一个__init__.py文件的文件夹就是包. 包的作用: ? 将文件夹/模块组织起来,来提高程序的结构性和可维护性. ? 目的不是运行,为了导入使用.包只是一种形式,包的本质就是一个模块 import: # 创建一个包,也会发生三件事: ''' 1. 将该aaa包内 __init__py文件加载到内存. 2. 创建一个以aaa命名

python基础学习日志day5-各模块文章导航

python基础学习日志day5---模块使用 http://www.cnblogs.com/lixiang1013/p/6832475.html python基础学习日志day5---time和datetime模块 http://www.cnblogs.com/lixiang1013/p/6848245.html python基础学习日志day5---random模块http://www.cnblogs.com/lixiang1013/p/6849162.html python基础学习日志da

python 的日志logging模块学习

最近修改了项目里的logging相关功能,用到了python标准库里的logging模块,在此做一些记录.主要是从官方文档和stackoverflow上查询到的一些内容. 官方文档 技术博客 基本用法 下面的代码展示了logging最基本的用法. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 # -*- cod

python 的日志logging模块

1.简单的将日志打印到屏幕 import logging logging.debug('This is debug message') logging.info('This is info message') logging.warning('This is warning message') <strong>屏幕上打印:</strong><br /> WARNING:root:This is warning message 默认情况下,logging将日志打印到屏幕,

Python写自动化之logging日志写入

日志写入是我们日常工作中常用到的功能,我们可以直接使用写文件的方式来以自己的方式写日志,另外,当我们在一个比较大的项目中,涉及到日志写入时,一般会使用logging模块来进行日志的写入,第一步,先写一个单例,创建一个logger对象: def _instance(): global logger if logger is None: logging.config.fileConfig(os.path.join(util.get_current(), "logger.conf")) lo

python的日志logging模块性能以及多进程

写在前面: 日志是记录操作的一种好方式.但是日志,基本都是基于文件的,也就是要写到磁盘上的.这时候,磁盘将会成为一个性能瓶颈.对于普通的服务器硬盘(机械磁盘,非固态硬盘),python日志的性能瓶颈是多少呢?今天我们就来测一下. 测试代码如下: #! /usr/bin/env python#coding=utf-8 # ============================# Describe : 给平台提供的日志# D&P Author By: 常成功# Create Date: 2016/

python(38):日志logging模块学习

1.简单的将日志打印到屏幕 import logging logging.debug('This is debug message') logging.info('This is info message') logging.warning('This is warning message') 屏幕上打印: WARNING:root:This is warning message 默认情况下,logging将日志打印到屏幕,日志级别为WARNING:日志级别大小关系为:CRITICAL > ER

python 的日志logging模块学习【转】

1.简单的将日志打印到屏幕 import logging logging.debug('This is debug message') logging.info('This is info message') logging.warning('This is warning message') 屏幕上打印: WARNING:root:This is warning message 默认情况下,logging将日志打印到屏幕,日志级别为WARNING: 日志级别大小关系为:CRITICAL > E