python数据类型相关知识扩展
作者:florachy 发布时间:2021-12-21 10:20:07
一、命名元祖
在python基础中, 我们学习元祖的时候,取元祖内部的元素都是通过索引来进行取值的。但是这种取值方式不够友好, 所以我们引入命名元祖的方式对元祖进行字典式取值,这种方式比起字典存储占用的内存较少。如果数据不需要变化,可以用命名元祖替代字典。
常规元祖取值方式:
info = ("flora", 28, "女")
name = 0
age = 1
gender = 2
print(info[name]) # 获取姓名
print(info[age]) # 获取年龄
print(info[gender]) # 获取性别
命名元祖方式:
# namedtuple: 接收两个参数:第一个参数是创建的类型名称, 第二个参数是列表
from collections import namedtuple
info = namedtuple("info_key", ["name", "age", "gender"])
info_01 = info("flora", 28, "女")
print(info_01.name) # 获取姓名
print(info_01.age) # 获取年龄
print(info_01.gender) # 获取性别
print(info_01) # 打印结果:info_key(name='flora', age=28, gender='女')
二、在自动化测试场景中的应用
我们从excel中读取用例数据第一行表头是key, 每一行的值是value。如果作为字典格式存储格式如下:
case = [
{"case_id": 1,
"case_title": "正常登录",
"data": "test",
"expected": "pass"},
{"case_id": 2,
"case_title": "登录失败",
"data": "test",
"expected": "pass"},
]
我们可以把转成命名元祖的方式存储,如下:
# namedtuple: 接收两个参数:第一个参数是创建的类型名称, 第二个参数是列表
from collections import namedtuple
case = [
{"case_id": 1,
"case_title": "正常登录",
"data": "test01",
"expected": "pass"},
{"case_id": 2,
"case_title": "登录失败",
"data": "test02",
"expected": "pass"},
]
cases = namedtuple("case", case[0].keys())
for i in case:
result = cases(*i.values())
print(result.data)
# 打印结果: test01 test02
三、三目运算符
python中的三目运算符相当于java中的三元运算符。
基本语法
条件成立执行的结果 if 过滤条件 else 条件不成立执行的结果
实际应用
例如我们想要编写一个Python程序,输入两个数,比较它们的大小并输出其中较大者。相比起常规写法,三目运算符写法更加的简洁明了。
常规写法:
x = int(input("请输入第一个正整数:"))
y = int(input("请输入第二个正整数:"))
if x == y:
print("较大的数为:", x)
elif x > y:
print("较大的数为:", x)
else:
print("较大的数为:", y)
三目运算符写法:
x = int(input("请输入第一个正整数:"))
y = int(input("请输入第二个正整数:"))
print("较大的数为:{}".format(x if x > y else y))
扩展: 三目运算符的嵌套
Python 三目运算符支持嵌套,如此可以构成更加复杂的表达式。在嵌套时需要注意 if 和 else 的配对。
例如我们需要判断两个数字的关系。
常规写法:
a = int(input("请输入a:"))
b = int(input("请输入b:"))
if a > b:
print("a大于b")
else:
if a < b:
print("a小于b")
else:
print("a等于b")
三目运算符嵌套写法:
a = int(input("请输入a:"))
b = int(input("请输入b:"))
print("a大于b") if a > b else (print("a小于b") if a < b else print("a等于b"))
四、推导式
推导式 comprehensions(又称解析式),是 python 的一种独有特性。推导式是可以从一个数据序列构建另一个新的数据序列。
推导式的作用:快速生成数据。
列表推导式
常规列表推导式
基本语法:[每次遍历添加到列表的内容 for x in xxx]
实例:输出一个由0-100的数字组成的列表。
常规写法:
li = []
for i in range(101):
li.append(i)
print(li)
推导式写法:
li = [i for i in range(101)]
print(li)
列表推导式嵌套if
基本语法:[每次遍历添加到列表的内容 for x in xxx if 过滤条件]
实例:输出一个由0-100的偶数数字组成的列表。
常规写法:
li = []
for i in range(101):
if i % 2 == 0:
li.append(i)
print(li)
推导式写法:
li = [i for i in range(101) if i % 2 == 0]
print(li)
列表推导式结合三目运算符
基本语法:[if 过滤条件 else 条件 每次遍历添加到列表的内容 for x in xxx ]
实例:0-100个数,如果是偶数则返回偶数0, 如果是奇数则返回奇数1。
常规写法:
li = []
for i in range(101):
if i % 2 == 0:
li.append("偶数0")
else:
li.append("奇数1")
print(li)
列表推导式+三目运算符:
li = ["偶数0" if i % 2 == 0 else "奇数1" for i in range(101)]
print(li)
五、字典推导式
基本语法:{键:值 获取键值的表达式}
实例: 有一个列表li, 把他转换成一个元素下标为键,值为元素的字典格式的数据。
常规写法:
li = ["id", "title", "url", "data", "expected"]
dic = {}
for i, j in enumerate(li):
dic[i] = j
print(dic)
字典推导式写法:
li = ["id", "title", "url", "data", "expected"]
dic = {i: j for i, j in enumerate(li)}
print(dic)
来源:https://blog.csdn.net/FloraCHY/article/details/117046860


猜你喜欢
- 本文实例讲述了Python实现简单的多任务mysql转xml的方法。分享给大家供大家参考,具体如下:为了需求导出的格式尽量和navicat导
- 最近在做文章页盖楼显示的项目,数据来源是跟贴系统生成的UTF8格式的JSON数据。文章页的HTML编码格式是GB2312,在javascri
- 1.查询数据库当前进程的连接数: select count(*) from v$process; 2.查看数据库当前会话的连接数: elec
- 函数画图以 z = x 2 + y 2 为例#导入模块import numpy as npimport matplotlib.py
- 前面简单介绍了Python元组基本操作,这里再来简单讲述一下Python字典相关操作>>> dir(dict) #查看字段
- 内置数据类型文本类型:str数值类型: int,float,complex序列类型:list,tuple,range映射类型: dict集合
- 本文实例讲述了Zend Framework教程之资源(Resources)用法。分享给大家供大家参考,具体如下:Zend_Applicati
- antd 的 表单校验方法包括 validateFields 和 validateFieldsAndScroll里面可以接收校验字段数组,
- 自动生成api文档(不管是函数视图还是类视图都能显示)1.安装rest_framework_swagger库pip install djan
- Python2.7Mac OS抓取的是电影天堂里面最新电影的页面。链接地址: http://www.dytt8.net/html/gndy/
- OpenCV中在图片上输出中文一般需要借助FreeType库实现。FreeType库是一个完全免费(开源)的、高质量的且可移植的字体引擎,它
- 一、前言在Python开发的过程中,为了实现某项功能,经常需要对某些字符串进行特殊的处理,如拼接字符串、截取字符串、格式化字符串等。下面将对
- Selenium简介与安装 Selenium是什么? Selenium也是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏
- 我们来编写一个,引用时用:<!--#include Virtual="page.inc"-->语句即可:pa
- 后台数据库: [Microsoft Access] 与 [Microsoft Sql Server] 更换之后,ASP代码应注意要修改的一些
- 前言这篇文章算是论坛PyTorch Forums关于参数初始化和finetune的总结,也是我在写代码中用的算是“最佳实践”吧。最后希望大家
- 本文介绍机器学习中的Logistic回归算法,我们使用这个算法来给数据进行分类。Logistic回归算法同样是需要通过样本空间学习的监督学习
- 本文实例为大家分享了Django文件上传与下载的具体代码,供大家参考,具体内容如下文件上传1.新建django项目,创建应用stu: pyt
- 本文实例讲述了Python使用装饰器模拟用户登陆验证功能。分享给大家供大家参考,具体如下:# -*- coding:utf-8 -*-#!p
- 描述符(descriptor)是实现了__get__、__set__、__del__方法的类,进一步可以细分为两类:数据描述符:实现了__g