python基础训练营03——字典、集合、判断、循环
一、字典dict:
相比列表list而言,列表list像一本书,如果要查书中的某一个内容,需要把书从前往后翻一遍,直到找到想要获取的东西;而字典dict,就像现实中的字典一样,通过查找特定的字或者词(键key),从而找到相对应的它的定义和解释(value值)
1. 字典的标志:{ }
2. 字典的定义:
字典由多个键key和与其相对应的值value,构成键-值对,键-值对也称为项item。每项中的键和值之间,用冒号(:)隔开,项之间用逗号(,)隔开。整个字典用一对大括号{ }括起来。空字典不包括任何项,由两个大括号组成——{}
- 字典是python中唯一的内建的映射类型
- 字典是无序的
- 字典中的键key,是唯一的,值value不唯一。
- 键key:可以是任何不可变类型,如:数字、字符串、元组。
3. 基本操作:增删改查:
(1) len(d):返回字典d中,项item(键值对)的数量
(2) 字典名[键名]:返回字典中键相应的值
(3) 增/改:字典名[键名] = 值
- 如果键不存在,向字典中增加一项
- 如果键存在,修改字典中的这一项
注意:字典和列表不同,字典是自动添加。即:即使起初,字典的键并不存在,也可以为他赋值,这样字典就会建立新的项,而无需使用append方法。
x= [] x[42] = 'football' >>报错 x = {} x [42] = 'football' x >>{42: 'football'}
(4) 删除:del 字典名[键名] ——删除该键名的项
(5) 查询:键名 in 字典名:键key是否在字典中。——检查成员资格。
注意:检查的是键,而不是值。
(6) dict函数:
dict()函数用于创建一个字典
#创建一个空字典 >>>dict() {} 5 #通过关键字,创建字典 >>>dict('name' = 'tom', 'age' = 20) {name: "tom", age: 20} #通过一个可迭代对象,创建字典 >>>dict(('name', 'tom'), ('age', 20))
4. 字典方法:
(1) clear():
用于:清除字典中的所有项,没有返回值(返回None)
eg:
>>>dict2 = {} >>>dict1['age'] = 20 >>>dict ['age': 20] >>> d = dict2.clear() >>>dict2 {} >>>d None
(2) copy():
返回:字典的一个浅复制
>>> x = {'one': 1, 'two': 2, 'three': [1, 2, 3]} >>> y = x.cpoy() >>> y {'one': 1, 'two': 2, 'three': [1, 2, 3]} >>> y['one'] = 000 >>> y {'one': 000, 'two': 2, 'three': [1, 2, 3]} >>> x {'one': 1, 'two': 2, 'three': [1, 2, 3]} >>> del y['two'] >>> y {'one': 000, 'three': [1, 2, 3]} >>> x {'one': 1, 'two': 2, 'three': [1, 2, 3]} >>> y['three'][1] = 5000 >>> y {'one': 000, 'three': [1, 5000, 3]} >>> x {'one': 1, 'two': 2, 'three': [1, 5000, 3]}
可以看到,直接对字典内的“一级元素”,进行操作时,对副本y操作,原始字典x不受影响。但是当对“元素的元素”进行操作时,操作副本y,原始字典x也会发生改变。
所以说,浅拷贝,不是一个完完全全独立的副本。
避免的方法是,使用深拷贝(deep copy),需要调用copy模块的deepcopy函数。
直接赋值、浅拷贝、深拷贝的区别:只有涉及对象嵌套时,有区别
a、直接赋值:b = a: 赋值引用,a 和 b 都指向同一个对象。
b、浅拷贝:b = a.copy(): a 和 b 是一个独立的对象,但他们的子对象还是指向统一对象(是引用)。
c、深拷贝:b = copy.deepcopy(a): a 和 b 完全拷贝了父对象及其子对象,两者是完全独立的。
3. fromkeys(seq, val):
以序列seq中的元素,作为字典中的键,以val作为每个键对应的初始值,val默认值是None
>>> dict.fromkeys([1, 2, 3]) {1: None, 2: None, 3: None} >>> dict.fromkeys([1, 2, 3], ('val')) {1: 'val', 2: "val", 3: 'val'}
4. get(key, default = None):
获取字典中,指定键key的值value,如果该键key,不存在。则返回默认值
>>> x = {1: 'one', 2: 'two', 3: 'three'} >>> x.get(1) 'one' >>> x.get(5) None >>> x.get(5, '不存在') '不存在'
5. key in dict
键名 in 字典名
判断键key,是否在字典中,是,返回True;否则:返回False
>>> d = {1: "A", 2: "B", 3: "C"} >>> 1 in d True >>> 5 in d False
6. items():
items()方法,返回字典中的所有项(键-值对),返回的是一个迭代器对象,使用list()函数,可以使之变为列表list,以列表的方式返回,列表中的每一项都表示为(键,值)的形式,项在返回时没有遵循特定的顺序。
>>> d = {1:"A", 2: "B", 3: "C"} >>> d.items() dict_items([(1, "A"), (2, "B"), (3, "C")]) #迭代器对象 >>> list(d.items()) [(1, "A"), (2, "B"), (3, "C")]
7. keys():
keys()方法,将字典中的键key,以返回,返回的是一个迭代器,使用list()函数,可以使之变为列表list
>>> d = {1:"A", 2: "B", 3: "C"} >>> d.keys() dict_keys([1, 2, 3]) #迭代器对象 >>> list(d.keys()) [1, 2, 3]
8. values():
values()方法,将字典中的键value,以返回,返回的是一个迭代器,使用list()函数,可以使之变为列表list
>>> d = {1:"A", 2: "B", 3: "C"} >>> d.values() dict_values(["A", "B", "C"]) #迭代器对象 >>> list(d.values()) ["A", "B", "C"]
9. pop(key):
pop(key),移出指定的键key的键值对,然后方法返回指定的键key的值value。
>>> d = {1:"A", 2: "B", 3: "C"} >>> d.pop(1) "A" #返回了pop中的键,对应的value值 >>> d {2: "B", 3: "C"} #pop中对应的键值对,被从字典中删除了
10. popitem():
字典中的 popitem()方法和列表list中的pop()方法相似,不过,由于字典是无序的,所以:popitem()弹出的是随机的项item
11. setdefault(key, default = None):
a、setdefault() 方法和 get()类似,:
- 如果键key存在于字典中,则返回对于的值value
- 如果键不已经存在于字典中,则返回:参数default默认值,并且将会添加键key并将值value设为默认值default。
b、参数含义:
- key: 查找的键的值
- default:键key不存在于字典中时,设置到默认值default
c、返回值:
如果 key 在 字典中,返回对应的值。如果不在字典中,则插入 key 及设置的默认值 default,并返回 default ,default 默认值为 None
>>> dict1 = {'Name': 'Runoob', 'Age': 7} >>> dict1.setdefault("Age",None) 7 >>> dict1 {'Name': 'Runoob', 'Age': 7} >>> dict1.setdefault("Sex") None >>> dict1 {'Name': 'Runoob', 'Age': 7, "Sex": None} >>> dict1.setdefault("address", "unknow") "unknow" >>> dict1 {'Name': 'Runoob', 'Age': 7, "Sex": None, "address": unkown)
12. update():
update() 函数把字典参数 dict2 的 key/value(键/值) 对更新到字典 dict 里。
>>> dict = {'Name': 'Runoob', 'Age': 7} >>> dict2 = {'Sex': 'female' } >>> dict.update(dict2) >>> dict {'Name': 'Runoob', 'Age': 7, 'Sex': 'female' }
二、集合set:
集合(set)是一个无序的不重复元素序列。
三、条件判断:
1. if判断结构,一般形式:
if condition_1: statement_block_1 elif condition_2: statement_block_2 else: statement_block_3
——如果condition_1为True,则执行statement_block_1代码块;
——如果condition_2为False,则判断condition_2;
——如果condition_2为True,则执行statement_block_2代码块;
——如果condition_2为False,则执行statement_block_3代码块;
注意:
- 每个条件后面,都要有冒号(:)
- 使用缩进来划分语句块,相同缩进数的语句在一起组成一个语句块。
- if语句可以嵌套
2. 常用的操作符:
逻辑操作符:and、or、not
注意:逻辑操作符,执行的是短路逻辑。
即:
(1)if conditon_A and condition_B:
先看conditon_A 是True还是False,如果是False,就直接返回False,不用再去看condition_B
(2)if conditon_A or condition_B:
同理,先看conditon_A是True还是False,如果是True,就直接返回True,不用再去判断condition_B
3.三目运算符:
4.关于布尔值:
四、循环:
1.while循环:
while 条件表达式: 代码块
(1) 无限循环:
可以通过设置条件表达式永远不为 false 来实现无限循环,无限循环在服务器上客户端的实时请求非常有用。
可以使用 CTRL+C 来退出当前的无限循环。
(2) while循环使用else语句:
while … else 在条件语句为 false 时执行 else 的语句块:
while 条件表达式: 代码块1 else: 代码块2
(3) 简单while语句:
当while循环的循环体中只有一条语句时,while循环可以简写成一句话
while 条件表达式: 循环体代码块
eg:
flag = 1 while (flag): print("hello world")
2.for循环:
for <variable> in <sequence>: <statements_1> else: <statements_2>
(1) range()函数:
rang(下限,上限,步长)
下限默认为0;步长默认为1
range()函数会一次性创建整个序列,它包括下限,不包括上限。
>>> range(1, 7, 2) [1, 3, 5]
3.break语句:
直接跳出当前层的循环
4. continue语句:
continue语句被用来告诉Python跳过当前循环块中的剩余语句,然后继续进行下一轮循环。
5.循环的else语句:
循环语句可以有 else 子句,
- 它在穷尽列表(以for循环)时,被执行
- 条件变为 false (以while循环)导致循环终止时被执行
- 但循环被break终止时不执行。
6. pass语句:
pass语句是空语句,不做任何作用,只用来占位
python基础训练营03——字典、集合、判断、循环的更多相关文章
- Python基础2 列表 字典 集合
本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...
- 『Python基础-10』字典
# 『Python基础-10』字典 目录: 1.字典基本概念 2.字典键(key)的特性 3.字典的创建 4-7.字典的增删改查 8.遍历字典 1. 字典的基本概念 字典一种key - value 的 ...
- Python基础知识(五)------字典
Python基础知识(四)------字典 字典 一丶什么是字典 dict关键字 , 以 {} 表示, 以key:value形式保存数据 ,每个逗号分隔 键: 必须是可哈希,(不可变的数据类型 ...
- python基础(二)条件判断、循环、格式化输出
继续上一篇,今天主要总结一下条件判断.循环.格式化输出 一.条件判断 python中条件判断使用if else来判断,多分支的话使用if elif ... else,也就是如果怎么怎么样就怎么怎么样, ...
- Python基础数据类型之字典
基础数据类型之字典 ps:数据类型划分:可变数据类型和不可变数据类型. 不可变数据类型:元组(tupe).布尔值(bool).整数型(int).字符串(str).不可变数据类型也称为可哈希. 可变 ...
- **python中列表 元组 字典 集合
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...
- python 基础学习(字典对象,set对象)
1.dict 字典对象 a.定义对象 d={'a':14,'b':12}b.通过key获取value d['a'] 方法1.判断key是否存在 if 'a' in d: d['a']方法2:通过用ge ...
- python中列表 元组 字典 集合的区别
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...
- Python基础(6)--条件、循环
本文的主要内容是 Python 的条件和循环语句以及与它们相关的部分. 我们会深入探讨if, while, for以及与他们相搭配的else,elif,break,continue和pass语句. 本 ...
随机推荐
- HDU 1222 Wolf and Rabbit(数学,找规律)
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission( ...
- 在VS2010 中使用subversion 进行代码的分支与合并
在实际开发总,遇到了这种情况: 开发版本1,开发版本2 ,更新产品时要求1在前,2在后. 但是因为时间要求,必须2个版本同时开发.这时就想到了在svn的版本分支合并. 创建分支之前,首先把当前版本代码 ...
- JavaScript函数的方法
在一个对象中绑定函数,称为这个对象的方法. 在JavaScript中,对象的定义是: var xiaoming = { name:'小明'; birth:1990; }; 但是,如果我们给xiaomi ...
- Linux学习——目录结构
在Linux当中,一切皆为文件,包括目录也属于文件.FHS(Filesystem Hierarchy Standard)的出现对文件目录系统做出了统一规范. Linux的目录结构: / - 根 /bi ...
- Oracle单行函数用法
单行函数分为五种类型:字符函数.数值函数.日期函数.转换函数.通用函数. 1.字符函数: 对于输入的字符转换为需要转为的字符或数值. upper()大写 --小写字母转为大写字母 --对于表指定的字符 ...
- jzoj100029. 【NOIP2017提高A组模拟7.8】陪审团(贪心,排序)
Description 陪审团制度历来是司法研究中的一个热议话题,由于陪审团的成员组成会对案件最终的结果产生巨大的影响,诉讼双方往往围绕陪审团由哪些人组成这一议题激烈争夺. 小 W 提出了一个甲乙双方 ...
- 【PTA 天梯赛训练】六度空间(广搜)
“六度空间”理论又称作“六度分隔(Six Degrees of Separation)”理论.这个理论可以通俗地阐述为:“你和任何一个陌生人之间所间隔的人不会超过六个,也就是说,最多通过五个人你就能够 ...
- oracle 12.1.0.2中对象锁对系统的较大影响
环境:oracle 12.1.0.2 rac ,4节点 一.概述 通常来说,如果是oltp应用,那么部署在rac上,是不错的注意. 但实现情况中,往往是混合类型,既有OLTP也有OLAP. 如果没有 ...
- Markdown基本使用
最近在写毕业论文,打算列个提纲,觉得有条理的搜集资料规划布局很重要,用Markdown写即有利于增强我的编写接口文档能力,也便于查看. markdown编写软件很多,markdownpad不错(mar ...
- 爬虫——Selenium与PhantomJS
Selenium Selenium是一个Web的自动化测试工具,最初是为网站自动化测试而开发的,类型像我们玩游戏用的按键精灵,可以按指定的命令自动操作,不同的是Selenium可以直接运行在浏览器上, ...