python基础之打/解包及运算符与控制流程
python基础之打/解包及运算符与控制流程
python中的解压缩(即序列类型的打包和解包)
python提供了两个设计元祖和其他序列类型的处理的便利,也就是自动打包与自动解包功能,比如:
data = 2,3,6,9
会使标识符data赋值成元祖(2,3,6,9),这种行为称为元祖的自动打包。在python中另一种常用的打包是从一个函数中返回多个值,如:
return x,y
就会返回单个对象,也就是元祖(x,y)。
作为一个对偶的打包行为,python也可以自动解包一个序列,允许单个标识符的一系列元素赋值给序列中的各个元素,具体如下:
a,b,c = range(1,4) #等同于a=1、b=2、c=3
list1 = ['name','age','gender','height']
s1,s2,s3,s4 = list1 # s1='name',s2='age',s3='gender',s4='height'
s1,_,_,s4 = list1 # 下划线表示不想要的数据,在这里只是用于占位
*_,s4 = list1 #如果有多个不想要的数据可以用*_代替
for k,v in mapping.items() #用于遍历字典的items()方法返回的键值对
自动打包与解包结合起来就是同时分配技术,即我们可以显式地将一系列的值赋给一系列的标识符,语法为:
x,y,z = 3,4,6
x,y = y,x #依赖于同时分配技术,省去了中间值
格式化输出的三种方式
长话短说,在python发展的过程中,出现了以下几种格式化输出:
name = 'DU'
age = 18
print("姓名:%s,年龄:%s" % (name, age)) #最开始的版本
print("姓名:{},年龄:{}".format(name, age)) #升级后的
print("姓名:{0},年龄:{1}".format(name, age)) #{}内是索引
print(f"姓名:{name},年龄:{age}") #以‘f'或’F'开头,直接在字符串内操作,推荐使用!
运算符和优先级
算术运算符:
+ 加 - 减 * 乘 / 除 // 整数除 % 模 ** 幂 比较运算符:
== 等价 != 不等价 < 小于 > 大于 <= 小于等于 >= 大于等于 逻辑运算符:
not 逻辑非 and 逻辑与 or 逻辑或 相等运算符:
is 同一实体 is not 不同实体 整数的位运算符:
~ 取反 & 按位与 | 按位或 ^ 按位异或 >> 右位移,按符号位填充 << 左位移,用零填充 序列运算符:
s[j] 索引下标为j的元素 s[start:stop] 切片,[start,stop)的序列 s[start:stop:step] 切片,start+step,start+2*step...直到结束 s+t 序列的连接 k*s s+s+s+s+....(k次) val in s 检查元素val在序列s中 val not in s 检查元素val不在序列s中 集合字典的运算符:
key in s 检查key是s的成员 key not in s 检查key不是s的成员 s1 == s2 s1等价s2 s1 != s2 s1不等价s2 s1 <= s2 s1是s2的子集 s1 < s2 s1是s2的真子集 s1 >= s2 s1是s2的超集 s1 > s2 s1是s2的真超集(s1不等于s2) s1 | s2 s1与s2的并集 s1 & s2 s1与s2的交集 s1 - s2 s1与s2的差集 s1 ^ s2 对称差分
运算符优先级:
类型 | 符号 | |
---|---|---|
成员访问 | expr.member | |
函数/方法调用 | expr(...) | |
容器下标/切片 | expr[...] | |
幂 | ** | |
一元运算符 | + expr, - expr,~expr | |
乘/除 | *,/,//,% | |
加/减 | +,- | |
按位位移 | <<,>> | |
按位与 | & | |
按位异或 | ^ | |
按位或 | | | |
比较 | is,is not,==,!=,in,not in等 | |
逻辑非 | not | |
逻辑与 | and | |
逻辑或 | or | |
条件判断 | val if cond else val2 | |
赋值 | =,+=,-=,*=等 |
控制流程
条件语句:
条件结构(也称if语句)提供了一种方法,用以执行基于一个或多个布尔表达式的运行结果而选择的代码块。在python中,条件语句一般形式如下:
if first_condition:
first_body
elif second_condition:
second_body
elif third_condition:
third_body
.
.
.
else :
else_body
其中每个条件都是布尔表达式,并且每个主体包含一个或多个在满足条件时才执行的命令。如果满足第一个条件,那么将执行第一个结构体,而其他条件或者结构体不会执行。如果不满足第一个条件,那么就这个流程就以相似的方式评估第二个条件,并继续。整体构造的执行将决定必有一个结构体会被执行。
循环语句
python提供了两种不同的循环结构。while循环允许以布尔条件的重复测试作为自出的一般重复。for循环对定义序列的值提供了适当的迭代(如字符串中的字符、列表中的元素或一定范围内的数字)。
while 循环
在python中的while循环的语法如下:
while condition:
body
执行while循环时首先测试布尔条件。如果条件为True,执行循环的主体。每次执行结构体后,重新测试循环条件,如果为True,那么开始另一轮迭代。如果条件为False,那么就终止循环。
例子:
j=0
while j < len(data) and data[j] != 'X':
j += 1
这里给出一个循环,通过字符序列的索引,找到一个输入值为‘X’的值或直接到达序列的尾部。
for 循环
在迭代一系列的元素时,python的for循环时一种比while更便利的选择。for循环的语法可以用在任何类型的迭代结构中,如列表、元组、str、集合、字典或文件。一般语法如下:
for element in iterable:
body
例如,我们考虑寻找一个列表的元素中寻找最大值(不使用max函数),假设列表中至少有一个元素:
biggest = data[0]
for val in data:
if val > biggest:
biggest = val
虽然我们也可以用while循环来完成上面任务,但for循环的优点就是简洁,即不需要管理列表的明确索引以及构造布尔循环条件。此外,我们还可以在while循环不适用的情况下使用for循环,例如遍历一个集合set,但是它不支持任何形式的索引。
基于索引的for循环:
虽然for循环可以遍历每一个元素,但是有一个限制就是我们不知道这个元素在序列的哪一个位置,所以我们需要用到range()
来遍历索引,比如我们想知道列表中最大元素的索引,我们可以这样:
big_index = 0
for i in range(len(data)):
if data[i] > data[big_index]:
big_index = i
break 和 continue 语句
break
在python中,当在循环体内执行break语句,while或for循环就会立即终止。如果在嵌套结构中使用break语句,它会导致内层循环立即终止。例如判断一个目标值是否出现在数据集中:
found = False
for i in data:
if i == target:
found = True
break
continue
continue语句会使循环体的当前迭代停止,但循环过程的后续迭代会正常运行。
我们建议慎用break和continue语句,然而有些情况下,可以有效的使用这些命令,以免引入过于复杂的逻辑条件。
扩展
与if相似的,while和for中也可以引用else
语句,else
语句只会在正常循环结束之后才会执行,如果遇到break,则不会执行else
,这个知识点仅作了解,一般开发过程中不会用到。
祝大家越来越棒!
python基础之打/解包及运算符与控制流程的更多相关文章
- 二十五. Python基础(25)--模块和包
二十五. Python基础(25)--模块和包 ● 知识框架 ● 模块的属性__name__ # my_module.py def fun1(): print("Hello& ...
- Python基础知识详解 从入门到精通(七)类与对象
本篇主要是介绍python,内容可先看目录其他基础知识详解,欢迎查看本人的其他文章Python基础知识详解 从入门到精通(一)介绍Python基础知识详解 从入门到精通(二)基础Python基础知识详 ...
- 第三节:带你详解Java的操作符,控制流程以及数组
前言 大家好,给大家带来带你详解Java的操作符,控制流程以及数组的概述,希望你们喜欢 操作符 算数操作符 一般的 +,-,*,/,还有两个自增 自减 ,以及一个取模 % 操作符. 这里的操作算法,一 ...
- Python基础二. 数据结构、控制流、运算符、真值测试
一.概述 数据结构上广义上有两种,单一类型和集合类型 单一类型,表示一种对象 集合类型,表示包含多种对象 Python 中的内建的数据类型有str.list.tuple.dict.set.number ...
- Python特色的序列解包、链式赋值、链式比较
一.序列解包 序列解包(或可迭代对象解包):解包就是从序列中取出其中的元素的过程,将一个序列(或任何可迭代对象)解包,并将得到的值存储到一系列变量中. 一般情况下要解包的序列包含的元素个数必须与你在等 ...
- 第4.7节 Python特色的序列解包、链式赋值、链式比较
一.序列解包 序列解包(或可迭代对象解包):解包就是从序列中取出其中的元素的过程,将一个序列(或任何可迭代对象)解包,并将得到的值存储到一系列变量中. 一般情况下要解包的序列包含的元素个数必须与你在等 ...
- Python基础学习笔记(三)运算符
参考资料: 1. <Python基础教程> 2. http://www.runoob.com/python/python-chinese-encoding.html 3. http://w ...
- 2.Python基础认识(格式化输出,while语句,运算符,编码,单位转化)
Python基础认识 1.字符串的格式化初识及占位符的简单应用 字符串的格式化 按照既定的要求进行有规定排版的一种输出方式. #我们想要输出的格式如下: ----------------------- ...
- python基础(5):格式化输出、基本运算符、编码问题
1. 格式化输出 现在有以下需求,让⽤户输入name, age, job,hobby 然后输出如下所⽰: ------------ info of Alex Li ----------- Name : ...
随机推荐
- 基于ABP做一个简单的系统——实战篇:2.代码生成器
上一篇正说着呢,代码生成器就来了. 1.适用于ABP官网的Startup Template V3.x的包含了登录.用户等页面的MPA应用模板2.当前view仅支持文本框生成,远期规划根据字段类型生成不 ...
- pytest 多个PY文件执行共享变量及用fixture和conftest
------------恢复内容开始------------ 1.pytest需要测试多个py文件,这些文件有一定的依赖关系,同时执行的时候,需要只执行一次初始化setup,结束再执行一次teardo ...
- call,apply,bind的理解
2020-03-19 call,apply,bind的理解 先说区别call, apply基本上没什么不一样,唯一不一样的地方是传参方式不同 但是bind和call,apply有区别.bind是重新绑 ...
- DML_The OUTPUT Clause
DML_The OUTPUT Clause /**/ ------------------------------------------------------------------------- ...
- 错误处理函数-lr_continue_on_error
在脚本的Run-time Settings中,可以设置在脚本运行过程中发生错误的处理方式.进入到Run-time Settings中,切换到Miscellaneous标签页,可以看到Error Han ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(七)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- Homebrew命令总结
brew又叫homebrew,是macos上的一个包管理工具,能够在mac中方便的进行包管理,类似于ubuntu系统下的apt-get,记得自己第一次接触brew是为了在mac上安装一个独立绿色的视频 ...
- cb49a_c++_STL_算法_对所有元素排序_sort_stable_sort
cb49a_c++_STL_算法_对所有元素排序_sort_stable_sort sort(b,e) sort(b,e,p) stable_sort(b,e) stable_sort(b,e,p) ...
- 关于GridView的横向合并数据信息
此为asp.net 运行展示: 前端代码: <%@ Page Language="C#" AutoEventWireup="true" CodeBehin ...
- Docker拉取镜像加速
关于Docker拉取镜像加速 打开桌面 docker 小图标 选中框框 根据下图 添加国内的加速源即可 Docker加速源 #网易 http://hub-mirror.c.163.com #Docke ...