软件测试|Python基础之包的使用和软件开发目录规范及常用内置模块

简介: 软件测试|Python基础之包的使用和软件开发目录规范及常用内置模块

在这里插入图片描述

包的使用

  1. 什么是包
  • 指含有多个py文件的集合
  • 指内部含有__ init__ .py文件的文件的文件夹
  1. 包的具体使用
  • 常规导入

如果只是想使用包中某几个模块,只需按照常规from...import...的导入方式使用即可

  • 直接导入包名

使用import的方式直接导入包名
代码表现:
import 包名
这种方式导入的是包内__ init _ .py文件,通常包的开发人员会将包内模块名导入到这个文件中去,我们只需要通过’包‘点_' init __'点''模块名''的方式调用

软件目录开发规范

为了提高程序的可读性与可维护性,我们应该为软件设计良好的目录结构,这与规范的编码风格同等重要,简而言之就是把软件代码分文件目录,做到可读性强,可维护性高

  1. bin
  • bin 主要用来存放项目启动文件

    • start.py 启动文件可以存放在这个文件夹内,也可以直接存放在项目根目录下
  1. conf
  • conf 主要用来存放项目配置文件

    • settings.py 存放项目的默认配置,这里的文件一般全是大写
  1. core
  • core 主要用来存放项目的核心功能文件

    • src.py 项目核心功能文件
  1. interface
  • interface 主要用来存放项目接口类文件,根据具体业务逻辑划分文件

    • goods、user、account 等文件
  1. db
  • db 主要用来存放数据相关的文件(用户信息、用户账号)

    • userinfo、db_handler 等文件
  1. log
  • log 主要用来存放项目日志类型文件(项目运行情况)

    • log.log
  1. lib
  • lib 主要用来存放项目公共功能等文件

    • common.py
  1. readme
  • readme 主要用来存放项目的使用说明和一些介绍
  1. requirements
  • requirements 主要用来存放项目所需的模块和版本

常用内置模块

1、collections模块

  1. 具名元组

关键词:namedtuple(可迭代对象,导入的序列)
作用:可生成具体名称元组

导入模块:
    from collections import namedtuply

用法一:表示二位坐标
    point = namedtuple('坐标', ['x', 'y'])
    p1 = point(1, 2)
    print(p1)
    print(p1.x)
    print(p1.y)
-------------------------------------------------------------------------------------
    坐标(x=1, y=2)
    1    
    2
    
    
用法二:表示扑克牌
     card = namedtuple('扑克牌', ['num', 'color'])
    c1 = card('A', '黑♠')
    c2 = card('A', '红♥')
    print(c1, c1.num, c1.color)
    print(c2, c2.num, c2.color)
    
-----------------------------------------------------------------------------
    扑克牌(num='A', color='黑♠') A 黑♠
    扑克牌(num='A', color='红♥') A 红♥
  1. 双端队列

关键词:deque(可迭代对象,最大数据值)
作用:可生成双向列表,返回一个新的双向队列对象,从左到右初始化(用方法 append()) ,从 iterable (迭代对象) 数据创建。如果 iterable 没有指定,新队列为空。

导入模块:
    from eollections import deque

用法:
    q = deque(['a', 'b', 'c'], maxlen=10)
    # 从右边添加一个元素
    q.append('d')
    print(q) # deque(['a', 'b', 'c', 'd'], maxlen=10)

    # 从左边删除一个元素
    print(q.popleft()) # a
    print(q) # deque(['b', 'c', 'd'], maxlen=10)

    # 扩展队列
    q.extend(['i', 'j'])
    print(q) # deque(['b', 'c', 'd', 'i', 'j'], maxlen=10)

    # 查找下标
    print(q.index('c')) # 1

    # 移除第一个'd'
    q.remove('d')
    print(q) # deque(['b', 'c', 'i', 'j'], maxlen=10)

    # 逆序
    q.reverse()
    print(q) # deque(['j', 'i', 'c', 'b'], maxlen=10)

    # 最大长度
    print(q.maxlen) # 10
  1. 默认值字典

关键词:defaultdict
作用:默认字典的功能与dict基本相同,但在访问一个不存在的key时,默认字典会提供一个默认值,而不是引发异常

导入模块:
from eollections import defauldict

用法一:
     #  使用 list 作为 default_factory ,很容易将序列作为键值对加入字典:
    d = defaultdict(list)
    s = [('yellow', 1), ('blue', 2), ('yellow', 3), ('blue', 4), ('red', 1)]

    for k, v in s:
        d[k].append(v)

    print(d) # defaultdict(<class 'list'>, {'yellow': [1, 3], 'blue': [2, 4], 'red': [1]})
    
用法二:
     #  设置 default_factory 为 int ,可以很好的用于计数
    s = 'mississippi'
    d = defaultdict(int)
    for k in s:
    d[k] += 1

    print(d) # defaultdict(<class 'int'>, {'m': 1, 'i': 4, 's': 4, 'p': 2})
    
  1. 计数

关键词:Counter
作用:Counter 是一个 dict 的子类,用于计数可哈希对象

导入模块:
    from eollections import counter

用法一:统计字符串字符个数
    c = Counter()
    str_1 = 'sfsadfsdjklgsdla'
    for i in str_1:
        c[i] +=  1

    print(c) # Counter({'s': 4, 'd': 3, 'f': 2, 'a': 2, 'l': 2, 'j': 1, 'k': 1, 'g': 1})

    c2 = Counter('asfjslfjsdlfjgkls')
    print(c2) # Counter({'s': 4, 'd': 3, 'f': 2, 'a': 2, 'l': 2, 'j': 1, 'k': 1, 'g': 1})

用法二:统计列表相同数据值个数
    c = Counter(['red', 'blue', 'red', 'green', 'blue', 'blue'])
    print(c) # Counter({'blue': 3, 'red': 2, 'green': 1})

2、time时间模块

在python中,有三种表现时间的结构
1、时间戳:1970年0时0分0秒-到现在的秒速
2、结构化时间:计算机看的,人看不适应
3、格式化时间:主要是表示时间的年月日
  1. 时间戳

关键词:time
作用:打印一个时间戳

模块导入:
    import time/from time import time

    print(time.time())  # 1666170099.7668478
  1. 结构化时间

关键词:localtime
作用:打印结构化时间

模块导入:
    import time/from time import localtime

    print(time.localtime())  # time.struct_time(tm_year=2022, tm_mon=10, tm_mday=19, tm_hour=17, tm_min=4, tm_sec=16, tm_wday=2, tm_yday=292, tm_isdst=0)
  1. 格式化时间

关键词:strftime
作用:以人能看懂的方式打印时间

模块导入:
    import time/from time import strftime
    
    print(time.strftime('%y/%m/%d'))    # 22/10/19
    print(time.strftime('%y-%m-%d,%H:%M:%S'))    # 22-10-19,17:19:17
    print(time.strftime('%y年%m月%d日%H时%M分%S秒')) # 22年10月19日17时19分17秒
  1. 睡眠

关键词:sleep
作用:代码执行到此处时,可以设置暂停执行的时间

模块导入:
    import time/from time import sleep
    
    time.sleep(10)
    print('怎么还没到我~')    # 代码将在10秒后打印    
  1. datetime类
导入模块:
    import datetime
    
print(datetime.datetime.today())  # 2022-10-19 18:22:06.371652
print(datetime.datetime.now())   # 2022-10-19 18:24:13.345563
print(datetime.date.today())  # 2022-10-19
相关文章
|
2月前
|
Java 测试技术 持续交付
探索自动化测试在软件开发中的关键作用与实践
在现代软件开发流程中,自动化测试已成为提升产品质量、加速交付速度的不可或缺的一环。本文深入探讨了自动化测试的重要性,分析了其在不同阶段的应用价值,并结合实际案例阐述了如何有效实施自动化测试策略,以期为读者提供一套可操作的实践指南。
|
3月前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
WK
|
3月前
|
开发者 Python
Python 设计规范
Python的设计规范覆盖了代码布局、命名、注释、函数编写及模块化设计等多个方面,旨在提升代码的可读性与维护性。其中包括缩进、行宽、空行等布局要求;变量、函数、类等命名规则;单行与多行注释说明;函数长度与职责划分;模块的单一职责、开放封闭与依赖倒置原则;避免硬编码并使用有意义的命名;以及遵循PEP 8官方编码标准,以确保代码风格的一致性。遵循这些规范能帮助开发者编写更高质量且易于维护的Python代码。
WK
132 2
|
6天前
|
数据采集 算法 测试技术
【硬件测试】基于FPGA的QPSK调制解调系统开发与硬件片内测试,包含信道模块,误码统计模块,可设置SNR
本文介绍了基于FPGA的QPSK调制解调系统的硬件实现与仿真效果。系统包含测试平台(testbench)、高斯信道模块、误码率统计模块,支持不同SNR设置,并增加了ILA在线数据采集和VIO在线SNR设置功能。通过硬件测试验证了系统在不同信噪比下的性能,提供了详细的模块原理及Verilog代码示例。开发板使用说明和移植方法也一并给出,确保用户能顺利在不同平台上复现该系统。
48 15
|
14天前
|
数据采集 算法 数据安全/隐私保护
【硬件测试】基于FPGA的2FSK调制解调系统开发与硬件片内测试,包含信道模块,误码统计模块,可设置SNR
本文介绍了基于FPGA的2FSK调制解调系统,包含高斯信道、误码率统计模块及testbench。系统增加了ILA在线数据采集和VIO在线SNR设置模块,支持不同SNR下的硬件测试,并提供操作视频指导。理论部分涵盖频移键控(FSK)原理,包括相位连续与不连续FSK信号的特点及功率谱密度特性。Verilog代码实现了FSK调制解调的核心功能,支持在不同开发板上移植。硬件测试结果展示了不同SNR下的性能表现。
57 6
|
29天前
|
机器学习/深度学习 人工智能 测试技术
探索自动化测试在软件开发中的重要性
随着软件开发行业的迅速发展,软件的质量和可靠性成为了企业关注的焦点。自动化测试作为一种高效的质量保障手段,其在软件开发生命周期中的应用越来越广泛。本文将探讨自动化测试的概念、优势以及在不同阶段的实施策略,旨在为软件开发团队提供一种提升产品质量和开发效率的有效途径。
43 2
|
29天前
|
敏捷开发 测试技术 持续交付
自动化测试之美:从零开始搭建你的Python测试框架
在软件开发的马拉松赛道上,自动化测试是那个能让你保持节奏、避免跌宕起伏的神奇小助手。本文将带你走进自动化测试的世界,用Python这把钥匙,解锁高效、可靠的测试框架之门。你将学会如何步步为营,构建属于自己的测试庇护所,让代码质量成为晨跑时清新的空气,而不是雾霾中的忧虑。让我们一起摆脱手动测试的繁琐枷锁,拥抱自动化带来的自由吧!
|
2月前
|
机器学习/深度学习 人工智能 测试技术
探索自动化测试框架在软件开发中的应用与挑战##
本文将深入探讨自动化测试框架在现代软件开发过程中的应用,分析其优势与面临的挑战。通过具体案例分析,揭示如何有效整合自动化测试以提升软件质量和开发效率。 ##
|
2月前
|
监控 测试技术 持续交付
探索自动化测试在软件开发中的最佳实践
本文旨在深入探讨自动化测试在软件开发过程中的应用,以及如何有效地实施自动化测试以提高软件质量和开发效率。通过分析自动化测试的优势、挑战和最佳实践,本文为软件开发团队提供了一套实用的指导方案。
|
27天前
|
机器学习/深度学习 人工智能 自然语言处理
探索自动化测试在软件开发生命周期中的关键作用
在当今快节奏的软件开发环境中,自动化测试已成为确保软件质量和加速产品上市时间的重要工具。本文深入探讨了自动化测试在软件开发生命周期(SDLC)各个阶段的应用和效益,包括需求分析、设计、编码、测试和维护等环节。通过具体案例分析,展示了自动化测试如何帮助团队提高测试效率、减少人为错误并缩短产品迭代周期。文章还讨论了实施自动化测试时面临的挑战,如选择合适的工具、编写可维护的测试脚本和处理动态变化的需求,以及如何克服这些挑战的策略。最后,提出了自动化测试的未来趋势,强调了持续集成/持续部署(CI/CD)流程中自动化测试的重要性,以及人工智能和机器学习技术在自动化测试领域的潜力。