gpt4 book ai didi

Python基础之常用库常用方法整理

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 26 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Python基础之常用库常用方法整理由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

1、os

?
1
2
3
4
5
6
7
8
__file__     
获取当前运行的.py文件所在的路径(D:\PycharmProjects\My_WEB_UI\ConfigFiles\ConfigPath.py)
 
os.path.dirname(__file__)
上面正在运行的.py文件的上一级(D:\PycharmProjects\My_WEB_UI\ConfigFiles)
 
os.path.join(xxx,u 'ConfigFiles\elementLocation.ini' )
在已获得的路径xxx上加上\ConfigFiles\elementLocation.ini

2、configparser

?
1
2
3
4
5
6
7
8
9
10
11
config = configparser.ConfigParser()
创建一个configparser对象
 
config.read(filename)
读取ini文件,filename为ini文件的路径
 
config.sections()
得到ini文件内的所有的section,以列表的形式返回
 
config.items(sectionName)
根据section的name得到其下的所有键值对,再用 dict (config.items(sectionName))封装为字典形式

3、openpyxl

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
wb = load_workbook( 'a.xlsx' )
读取文件a.xlsx
 
sheet = wb[sheetname]
根据名字拿到xlsx文件里对应的页
 
sheet.max_row
获取当前页的最大行数
 
sheet.max_column
获取当前页的最大列数
 
sheet.cell(row = xxx,column = xxx).value
获取单元格(xxx,xxx)中的值
 
sheet.cell(row = xxx,column = xxx).value = aa     #修改单元格里的值
wb.save(a.xlsx的路径名)                           #修改完要保存一下,否则修改不生效

openpyxl库中没有方法来获取去某一行的值,可以自定义

?
1
2
3
4
row_data = []
for i in range ( 1 ,sheet.max_column + 1 ):             #注意遍历列的时候从1开始
      cell_value = sheet.cell(row = xxx,column = i).value         #xxx就为具体想要获取的行
      row_data.append(cell_value)

4、loguru

?
1
2
3
4
5
6
logger.debug( 'this is a debug message' )
logger.info( 'this is a info message' )
logger.warning( 'this is a warning message' )
logger.error( 'this is a error message' )
logger.success( 'this is a success message' )
logger.critical( 'this is a critical message' )

Python基础之常用库常用方法整理

?
1
2
3
4
5
6
7
8
logger.add( 'xxx.log' )
在当前同级目录下创建一个xxx.log文件,并将接下来的日志打印到xxx.log里面
 
logger.add( 'lowPath/xxx.log' )
在当前目录下创建一个文件夹lowPath,在其中创建xxx.log文件
 
logger.add(otherPath + '/xxx.log' )
事先获取其他的目录otherPath,在otherPath下创建xxx.log

5、time

?
1
2
3
4
5
time.sleep( 2 )
强制休眠两秒
 
time.strftime( '%Y-%m-%d_%H-%M-%S' )
接受当前时间元组,并最终返回对应格式的字符串

6、unittest

基本概念: testcase 测试用例,以test开头,执行顺序会按照方法名的ASCII码值来排序 test suite 测试套件,testloader把需要一起执行的测试用例加载到套件中,然后一起执行 test runner 执行测试用例并返回测试结果 test fixture 测试固件,对一个测试用例环境的搭建和销毁 。

常见断言: assertEqual(a,b,msg=None) 判断a和b是否相等 assertNotEqual assertTrue(a) 判断a是否为True assertFalse assertIs(a,b) 判断a is b assertIsNot assertIsNone(a) 判断a is None assertIsNotNone assertIn(a,b) 判断a in b assertNotIn assertIsInstance(a,b) 判断a是不是b的实例 assertIsNotInstance 断言失败会报AssertionError的错 。

编写测试用例 。

?
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
43
44
45
46
47
48
class TestDemo(unittest.TestCase):
继承unittest模块里的TestCase
 
         def setUp( self )
         准备环境,执行测试用例的前置条件
 
         def tearDown( self )
         环境还原,执行测试用例的后置条件
 
         def test_01( self )
         测试用例 1
        
  if __name__ = = '__main__' :
        unittest.main()
        执行当前文件以test开头的测试用例
 
  ########################################以下是实例##############################################
import time
import unittest
 
from selenium import webdriver
 
from Modules.LoginAction import LoginAction
 
 
class Login_test(unittest.TestCase):
 
     def setUp( self ):
         '''
         准备好环境,执行测试用例的前置条件
         :return:
         '''
         self .driver = webdriver.Chrome()
         self .driver.get( 'https://mail.163.com/' )
         self .driver.maximize_window()
 
     def tearDown( self ):
         time.sleep( 2 )
         self .driver.quit()
 
     def test_01( self ):
         loginAction = LoginAction()
         loginAction.do_login( self .driver, 'lsqtester001' , 'qwer123' )
         time.sleep( 2 )
         self .assertIn( 'lsqtester002' , self .driver.page_source)
 
if __name__ = = '__main__' :
     unittest.main()

组织测试用例 。

?
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
43
44
45
46
47
suit = unittest.TestSuite()
定义一个测试套件
 
suit.addTest(Login_test( 'test_01' ))
向套件中添加测试用例
 
runner = unittest.TextTestRunner()
runner.run(suit)
定义testrunner并执行已加入测试套件的测试用例
 
loader = unittest.TestLoader()
定义一个testloader对象
suit.addTest(loader.discover(TestcasesPath,pattern = 'Unittest*.py' ))
根据条件将测试用例加载到套件中
 
 
########################################以下是实例##############################################
import unittest
 
from ConfigFiles.ConfigPath import TestcasesPath
from TestCases.Unittest_login import Login_test
 
 
 
if __name__ = = '__main__' :
     # suit = unittest.TestSuite()
     # #向套件中添加测试用例
     # suit.addTest(Login_test('test_01'))
     # suit.addTest(Login_test('test_02'))
     #
     # runner = unittest.TextTestRunner()
     # runner.run(suit)
 
     '''
     用discover来组织测试用例
     discover(dir,pattern='Unittest*.py',top_level_dir=None)
     dir就是存放写用例的python文件的具体路径
     pattern就是在目录dir下找形式如同Unittest*.py这样的文件
     如果符合条件的.py文件里有load_test这个函数的话,就会加载该文件里的测试用例
     如果不存在load_test函数的话,就会默认加载文件里以test开头的测试用例函数
     '''
     suit = unittest.TestSuite()
     loader = unittest.TestLoader()
     suit.addTest(loader.discover(TestcasesPath,pattern = 'Unittest*.py' ))
 
     runner = unittest.TextTestRunner()
     runner.run(suit)

到此这篇关于Python基础之常用库常用方法整理的文章就介绍到这了,更多相关Python常用库常用方法整理内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://blog.csdn.net/qq_38175040/article/details/116125998 。

最后此篇关于Python基础之常用库常用方法整理的文章就讲到这里了,如果你想了解更多关于Python基础之常用库常用方法整理的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com