Python实战基础9-元组、字典、集合

news2024/11/18 6:43:46

一、元组

Python的元组与列表类似,不同职称在于元组的元素不能修改。元组使用(),列表使用[]。

'''
Python的元组与列表类似,不同之处在于元组的元素不能修改(增删改),
元组使用小括号(),列表使用方括号[]
list 列表
tuple 元组

定义:
名 = ()
注意:如果元组中只有一个元素,必须添加逗号('aa',),(1,)
可使用的方法:
    count()
    index()
可使用的关键字:
    in ,not in
    for ... in
    while

list(tuple)--->元组转成列表
tuple(list)--->列表转元组
'''

t3 = ('a','b','c','d','e','f')

t2 = list(t3)
print(t2) # ['a', 'b', 'c', 'd', 'e', 'f']

t1 = tuple(t2)
print(t1) # ('a', 'b', 'c', 'd', 'e', 'f')


a = ('et',88,66)
print(a) # ('et', 88, 66)

print(type(a)) # <class 'tuple'>

1、访问元组

atuple = ('hello',100,3.12)
print(atuple) # ('hello', 100, 3.12)

print(atuple[0]) # hello
print(atuple[1]) # 100
print(atuple[2]) # 3.12

2、修改元组

说明:python中不允许修改元组的数据,包括不能删除其中的元素。 

3、count,index

index和count与字符串和列表中的用法相同

 说明:注意是左闭右开区间

a = ('a','b','c','a','b')

print(a.index('a',1,4)) # 3
print(a.count('b')) # 2
print(a.count('d')) # 0

4、定义只有一个数据的元组

定义只有一个元素的元组,需要在唯一的元素后写一个逗号

a = (11)
print(a) # 11
print(type(a)) # <class 'int'>

a = (11,) # 只有一个元素的元组,必须要在元素后写一个逗号
print(a) # (11,)
print(type(a)) # <class 'tuple'>

5、交换两个变量的值

#第1种方式,使用中间变量
a = 3
b = 6
c = 0

c = a
a = b
b = c
print(a) # 6
print(b) # 3

#第2种方式,直接交换
a,b = 4,5
a,b = b,a
print(a) # 5
print(b) # 4

二、字典

1、列表的缺点

当存储的数据要动态添加、删除的时候,我们一般使用列表,但是列表有时会遇到一些麻烦。

#定义一个列表保存,姓名、性别、职业
nameList = ['xiaoZhang','男','木匠']

#当修改职业的时候,需要记忆元素的下标
nameList[2] = '铁匠'

#如果列表的顺序发生了变化,添加年龄
nameList = ['xiaoZhang',18,'男','铁匠']

#此时就需要记忆新的下标,才能完成名字的修改
nameList[3] = 'xiaoxiaoWang'
print(nameList) # ['xiaoZhang', 18, 'nan', 'xiaoxiaoWang']

有没有方法,既能存储多个数据,还能在访问元素的时候很方便就能够定位到需要的那个元素呢?

字典 

2、字典的使用 

定义字典的格式:{键1 : 值1 , 键2 : 值2 ,  键3 : 值3 , ..., 键n : 值n}

变量info为字典类型

info = {'name':'班长','id':100,'sex':'f','address':'湖南'}
print(info['name']) # 字典使用键来获取对应的值

说明:

  • 字典和列表一样,也能够存储多个数据
  • 列表中找某个元素时,是根据下标进行的;字典中找某个元素时,是根据‘名字’(就是冒号:前面的那个值,例如上面代码中的‘name’、‘id’、‘sex’)
  • 字典的每个元素由2部分组成,键:值。例如‘name’:'班长',‘name’为键,‘班长’为值
  • 键可以使用数字、字符串、布尔值、元组等不可变数据类型,但是一般会习惯使用字符串
  • 每个字典里的key都是唯一的,如果出现了多个key,后面的value会覆盖前一个key对应的value。 

在习惯上:

  • 列表更适合保存多个商品、多个姓名、多个时间,这样的相似数据;
  • 字典更适合保存一个商品的不同信息、一个人的不同信息,这样的不同数据。 

3、字典的增删改查

 3.1 查看元素

除了使用key查找数据,还可以使用get来获取数据

info={'name':'班长','age':18}
print(info['age'])# 获取年龄
#print(info['sex'])# 获取不存在的key,会发生异常

print(info.get('sex')) # 获取不存在的key,获取到空的内容,不会出现异常
print(info.get('sex','男')) # 获取不存在的key,可以提供一个默认值。

注意:获取默认值不会修改字典内容。

3.2 修改元素 

字典的每个元素中的数据都是可以修改的,只要通过key找到,即可修改

info = {'name':'班长', 'id':100}

print('修改之前的字典为 %s:',info)
# 修改之前的字典为 %s: {'name': '班长', 'id': 100}

info['id'] = 200  # 为已存在的键赋值就是修改

print('修改之后的字典为 %s:',info)
# 修改之后的字典为 %s: {'name': '班长', 'id': 200}

3.3 添加元素 

如果在使用 变量名['键'] = 数据 时,这个“键”在字典中,不存在,那么就会新增这个元素

info = {'name':'班长'}
print('添加之前的字典为:%s' % info)
# 添加之前的字典为:{'name': '班长'}

info['id'] = 100 # 为不存在的键值赋值就是添加元素
print('添加之后的字典为:%s' % info)
# 添加之后的字典为:{'name': '班长', 'id': 100}

3.4 删除元素

 对字典进行删除操作,有以下几种方法:

  • del
  • clear()

del删除指定的元素

info = {'name':'班长','id':100}
print('删除之前的字典为:%s' % info)
# 删除之前的字典为:{'name': '班长', 'id': 100}

del info['name']  # del 可以通过键删除字典里的指定元素
print('删除之后的字典为:%s' % info)
# 删除之后的字典为:{'id': 100}

del删除整个字典

info = {'name':'班长','id':100}
print('删除前,%s'%info)
# 删除前,{'name': '班长', 'id': 100}

del info # del也可以直接删除变量

print('删除后,%s'%info)
# NameError: name 'info' is not defined

 clear清空整个字典

info = {'name':'monitor','id':100}

print('清空前,%s'%info)
# 清空前,{'name': 'monitor', 'id': 100}

info.clear()
print('清空后,%s'%info)
# 清空后,{}

4、字典遍历 

4.1 遍历字典的key(键)

dic = {'name':'zhangsan','sex':'m'}
for key in dic.keys():
    print(key)
# 输出结果
# name
# sex

4.2 遍历字典的value(值)

dic = {'name':'zhangsan','sex':'m'}
for value in dic.values():
    print(value)
# 输出结果
# zhangsan
# m

4.3 遍历字典的项(元素)

dic = {'name':'zhangsan','sex':'m'}
for item in dic.items():
    print(item)
# 输出结果
# ('name', 'zhangsan')
# ('sex', 'm')

4.4 遍历字典的key-value(键值对)

dic = {'name':'zhangsan','sex':'m'}
for key,value in dic.items():
    print('key=%s,value=%s'%(key,value))
# 输出结果
# key=name,value=zhangsan
# key=sex,value=m

4.5 练习

1、 有一个列表persons,保存的数据都是字典

persons = [{'name': 'zhangsan', 'age': 18}, {'name': 'lisi', 'age': 20}, {'name': 'wangwu', 'age': 19},{'name': 'jerry', 'age': 21}]
要求让用户输入一个姓名,如果这个姓名在列表里存在,就提示用户名称已存在,添加失败;如果这个姓名在列表里不存在,提示让用户输入年龄,并将用户输入的姓名和年龄添加到这个列表里。

persons = [{'name': 'zhangsan', 'age': 18}, {'name': 'lisi', 'age': 20}, {'name': 'wangwu', 'age': 19},{'name': 'jerry', 'age': 21}]
username = input('请输入一个名字:')

for person in persons:
    if person['name'] == username:
        print('名字已存在,添加失败')
        break
else:
    userage = input('请输入年龄:')
    persons.append({'name':username,'age':int(userage)})
print(persons))

2. 有一个字典dict1 = {"a":100,"b":200,"c":300},使用代码,将字典的key和value互换,变成 {100:"a",200:"b",300:"c"}。

#使用字典推导式
dict1 = {'a':100,'b':200,'c':300}
dict2 = {v: k for k,v in dict1.items()}
print(dict2)

三、集合的使用

1、set的使用

集合(set)是一个无序的不重复元素序列,可以使用大括号{}或者set()函数创建集合

注意:创建一个空集合必须用set()而不是{},因为{}是用来创建一个空字典。

创建格式:

parame = {value01,value02,...}

或者

set(value)

2、添加元素

创建格式:

s.add(x)

将元素x添加到集合s中,如果元素已存在,则不进行任何操作

thisset = set(("Google", "Runoob", "Taobao"))
thisset.add("Facebook")
print(thisset) # {'Google', 'Runoob', 'Taobao', 'Facebook'}

还有一个方法,也可以添加元素,且参数可以是列表、元组、字典等,语法格式如下:

s.update(x) 

x可以有多个,用逗号分开。

thisset = set(("Google", "Runoob", "Taobao"))
thisset.update({1,3})
print(thisset) # {1, 3, 'Google', 'Taobao', 'Runoob'}
thisset.update([1,4],[5,6])
print(thisset) # {1, 'Google', 3, 4, 5, 6, 'Runoob', 'Taobao'}

 3、移除元素

s.remove(x)

将元素x从集合s中移除,如果元素不存在,则会发生错误。

thisset = set(("Google", "Runoob", "Taobao"))
thisset.remove("Taobao")
print(thisset) # {'Google', 'Runoob'}
thisset.remove("Facebook")
print(thisset) # KeyError: 'Facebook'

此外还有一个方法也是移除集合中的元素,且如果元素不存在,不会发生错误。格式如下所示:

s.discard(x)

thisset = set(("Google", "Runoob", "Taobao"))
thisset.discard("Facebook") # 不存在也不会发生错误
print(thisset) # {'Taobao', 'Google', 'Runoob'}

也可以设置随机删除集合中的一个元素,语法格式如下:

s.pop() 

thisset = set(("Google", "Runoob", "Taobao"))
x = thisset.pop()
print(x) # Taobao
print(thisset) # {'Runoob', 'Google'}

 4、set常见方法列表

方法描述
add()为集合添加元素
clear()移除集合中的所有元素
copy()拷贝一个集合
pop()随机移除元素
remove()移除指定元素
union返回两个集合的并集
update()给集合添加元素
difference()返回多个集合的差集
difference_update()移除集合中的元素,该元素在指定的集合也存在。
discard()删除集合中指定的元素
intersection()返回集合的交集
intersection_update()删除集合中的元素,该元素在指定的集合中不存在。
isdisjoint()判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。
issubset()判断指定集合是否为该方法参数集合的子集。
issuperset()判断该方法的参数集合是否为指定集合的子集
symmetric_difference()返回两个集合中不重复的元素集合。
symmetric_difference_update()移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。

5、练习

有一个无序且元素数据重复的列表nums, nums=[5,8,7,6,4,1,3,5,1,8,4],要求对这个列表里的元素去重,并进行降序排序。

nums=[5,8,7,6,4,1,3,5,1,8,4]
#方法一:调用列表的sort方法
num1 = list(set(nums))
num1.sort(reverse=True)
print(num1)

#方法二:使用sorted内置函数
print(sorted(list(set(nums)),reverse=True))

四、转换相关

1、执行字符串

使用python内置的eval函数,可以执行字符串里的python代码。使用这种方式,可以将字符串转换成为其他类型的数据。

x = '1+1'
print(eval(x)) # 2
print(type(eval(x))) # <class 'int'>

y = '{"name":"zhangsan","age":18}'
print(eval(y))
print(type(eval(y))) # <class 'dict'>

print(eval('1 > 2')) # False

eval('input("请输入你的姓名:")')

2、转换成为字符串

JSON(JavaScriptObjectNotation, JS对象简谱)是一种轻量级的数据交换格式,它基于ECMAScript的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。

JSON本质是一个字符串

JSON的功能强大,使用场景也非常广,这里只介绍如何使用Python的内置JSON模块,实现字典、列表或者元组与字符串之间的相互转换。

使用JSON的dumps方法,可以将字典、列表或者元组转换成为字符串。

import json

person = {'name': 'zhangsan', 'age': 18}
x = json.dumps(person)
print(x)  # {"name": "zhangsan", "age": 18}
print(type(x))  # <class 'str'>

nums = [1, 9, 0, 4, 7]
y = json.dumps(nums)
print(y)  # [1, 9, 0, 4, 7]
print(type(y)) # <class 'str'>

words = ('hello','good','yes')
z = json.dumps(words)
print(z) # ["hello", "good", "yes"]
print(type(z)) # <class 'str'>

使用json的loads方法,可以将格式正确的字符串转换成为字典、列表。

x = '{"name": "zhangsan", "age": 18}'
person = json.loads(x)
print(person)  # {'name': 'zhangsan', 'age': 18}
print(type(person)) # <class 'dict'>

y = '[1, 9, 0, 4, 7]'
nums = json.loads(y)
print(nums) # [1, 9, 0, 4, 7]
print(type(nums)) # <class 'list'>

五、通用方法

字符串、列表、元组、字典和集合,它们有很多相同点,都是由多个元素组合成的一个可迭代对象,它们都有一些可以共同使用的方法。

1、算术运算符

在python里,常见的算数运算符,有一些可以使用于可迭代对象,它们执行的结果也稍有区别。

运算符Python 表达式结果描述支持的数据类型
+[1, 2] + [3, 4][1, 2, 3, 4]合并字符串、列表、元组
-{1,2,3,4} - {2,3}{1,4}集合求差集集合
*['Hi!'] * 4['Hi!', 'Hi!', 'Hi!', 'Hi!']复制字符串、列表、元组
in3 in (1, 2, 3)True元素是否存在字符串、列表、元组、字典
not in4 not in (1, 2, 3)True元素是否不存在字符串、列表、元组、字典

1.1 +

加法运算符可以用于字符串、列表和元组,用来拼接多个可迭代对象,不能用于字典和集合(思考:为什么字典和集合不能使用)。

print("hello" + "world") # helloworld
print([1,2] + [3,4]) # [1, 2, 3, 4]

1.2 -

减法只能用于集合里,用来求两个集合的差集

print({1,6,9,10,12,3} - {4,8,2,1,3}) # {9, 10, 12, 6}

1.3 *

乘法运算符可以用于字符串、列表和元组,用来将可迭代对象重复多次,同样不能用于字典和集合。

print('ab' * 4) # abababab
print([1,2]*4) # [1, 2, 1, 2, 1, 2, 1, 2]

2、in

in和not in成员运算符可以用于所有的可迭代对象。但是需要注意的是,in和not in在对字典进行判断时,是查看指定的key是否存在,而不是value。

print('llo' in 'hello world') # True

print(3 in [1,2])  # False

print(4 in (1,2,3,4)) # True

3、遍历

通过for...in ...我们可以遍历字符串、列表、元组、字典、集合等可迭代对象

3.1字符串遍历

a_str = "hello world"
for char in a_str:
    print(char,end=' ') # h e l l o   w o r l d

3.2列表遍历

a_list = [1,2,3,4,5]
for num in a_list:
    print(num,end=' ') # 1 2 3 4 5

3.3元组遍历

a_turple = (1,2,3,4,5)
for num in a_turple:
    print(num,end=" ") # 1 2 3 4 5

3.4带下标的遍历

可迭代对象都可以使用enumerate内置类进行包装成一个enumerate对象。对enumerate进行遍历,可以同时得到一个可迭代对象的下标和元素。

nums = [12,9,8,5,4,7,3,6]
#将列表nums包装成enumerate对象
for i,num in enumerate(nums): # i表示元素下标,num表示列表里的元素
    print('第%d个元素是%d' %(i,num))
# 运行结果
# 第1个元素是9
# 第2个元素是8
# 第3个元素是5
# 第4个元素是4
# 第5个元素是7
# 第6个元素是3
# 第7个元素是6

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/545391.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VuePress 1.x 踩坑记录

文章目录 前言1.Node.js 版本问题2.侧边栏3.添加页面目录导航4.非首页 footer 不生效5.部署到 Github 的错误vuepress 的 docs 与 Github Pages 的 docs 目录冲突样式丢失 7.资源引用问题本地图片找不到引用 CSDN 图片报 403 错误 参考文献 前言 我的第二本开源电子书《后台开…

被问了100遍的 堆的基本功能如何实现? 绝了!!!

文章目录 堆的介绍堆的概念堆的结构 堆的向下调整算法建堆的时间复杂度 堆的向上调整算法堆的基本功能实现初始化堆打印堆堆的插入堆的删除获取堆顶的数据获取堆的数据个数堆的判空销毁堆 堆的介绍 堆的概念 堆&#xff1a;如果有一个关键码的集合K{k0,k1,k2,…,kn-1}&#x…

计算机图形学-GAMES101-9

前言 材质和光的相互作用很重要。VertexShader和FragmentShader。纹理贴图Texture mapping。 一、在三角形中插值 为什么要在三角形内部插值&#xff1f;虽然我们的操作很多是在三角形顶点上进行计算的&#xff0c;但是对于三角形内部我们也希望每个像素点能得到一个值&…

FLASH锁死,STLink烧程序烧完一次无法再烧?

ST烧程序烧完一次无法再烧&#xff0c;因为把烧录引脚占用&#xff0c;所以可以再配置一下。 &#xff08;平时不勾PA13和PA14&#xff0c;也是会通过PA13和PA14烤录&#xff0c;勾上是为了防止锁死FLASH&#xff09; 如果锁住&#xff0c;再烧烧不进去 卡点&#xff0c;按住复…

【踩坑无数终极0错版】mac-Parallels Desktop的windwos虚拟机安装最新夜神模拟器+burpsuite证书安装+app渗透

文章目录 前言一、安装夜神模拟器二、夜神模拟器配置三、安装证书与所需软件四、测试抓包总结 前言 不想说了&#xff0c;反正我吐了&#xff0c;直接看正文吧。 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、安装夜神模拟器 mac上是安装不成功…

Spring6新特性来了!便捷替代Feign封装RPC接口

spring6的新特性笔者最近也有在研究&#xff0c;其中在HttpServiceProxyFactory服务代理工厂的使用方式体验上&#xff0c;笔者认为极其像是在用Feign编写RPC接口&#xff0c;使用服务代理工厂我们只要在全局配置单例的服务代里工厂bean再维护一个http interface接口就能统一的…

跨域跨网访问延迟高?中科三方云解析智能线路提供最优解析方案

在日常工作生活中&#xff0c;大多数人都是直接通过域名访问web服务器&#xff0c;但计算机并不能直接识别域名&#xff0c;因此需要域名系统&#xff08;DNS&#xff0c;Domain Name System&#xff09;将域名翻译成可由计算机直接识别的IP地址&#xff0c;这个环节就是域名解…

MOSFET开关:电源变换器基础知识及应用

​MOSFET是一种常用的场效应晶体管&#xff0c;广泛应用于电源变换器中。电源变换器是一种将输入电源转换为输出电源的电路&#xff0c;通常用于电子设备中。在本文中&#xff0c;我们将介绍MOSFET开关及其在电源变换器中的基础知识和应用。 一、MOSFET开关的基础知识 MOSFET…

MySQL---单列索引(包括普通索引、唯一索引、主键索引)、组合索引、全文索引。

1. 索引 索引是通过某种算法&#xff0c;构建出一个数据模型&#xff0c;用于快速找出在某个列中有一特定值的行&#xff0c;不使用索 引&#xff0c;MySQL必须从第一条记录开始读完整个表&#xff0c;直到找出相关的行&#xff0c;表越大&#xff0c;查询数据所花费的 时间…

算法之单调栈常见题目

什么时候需要使用单调栈&#xff1f; 通常是一维数组&#xff0c;要寻找任意一个右边或者左边第一个比自己大或小的元素的位置&#xff0c;此时我们就想到可以使用单调栈了。 单调栈的本质是空间换时间&#xff0c;因为在遍历的过程中需要用一个栈来记录右边第一个比当前元素高…

电轨车运维作业vr实操培训平台训练一批高素质的维修型人才

卡车由于使用频繁、长期载重以及各种不可预测的外界作业技能人员的培训。基于web3d开发的卡车检修作业3d模拟仿真教学系统弥补了教学条件的不足&#xff0c;在提升培训效果、节省教学经费上有显著的作用。 深圳华锐视点研发的卡车检修作业3d模拟仿真教学系统实时动态展示三维仿…

GNN 学习记录

GNN 参考资料&#xff1a;https://www.bilibili.com/video/BV16v4y1b7x7 图网络为什么复杂 需要接受任意尺寸的输入没有固定的节点顺序和参考锚点&#xff08;比如文本是从前往后处理&#xff0c;图像是有像素点的&#xff0c;图没有起始点&#xff09;动态变化和多种模态的…

月入3000万,23岁美国女网红用AI分身交1000多男友!谈恋爱按分钟计费

来源 | 新智元 微信号&#xff1a;AI-era 【导读】这位23岁的女网红用GPT-4复刻了一个自己后&#xff0c;已经周入7万多美元了。不仅如此&#xff0c;短短几天内&#xff0c;候补名单上就排了差不多1万名男施主。 各种逼真的AI工具火了之后&#xff0c;各路心思活泛的选手都开…

Spring Boot 项目【前后端分离】 之架子搭建

Spring Boot 项目【前后端分离】 之架子搭建 注意如果看过我ssm项目的博客的项目的前端可以不需要看或者快速看一下即可 比较页面什么的一样主要是技术栈不同. 技术栈 - 使用了前后端分离&#xff0c;前端的主体框架Vue3&#xff0b;后端的基础框架Spring-Boot 1.前端技术栈…

SQL: STUFF()和FOR XML PATH的使用

STUFF(param1, startIndex, length, param2) 将param1中自startIndex(SQL中都是从1开始&#xff0c;而非0)起&#xff0c;删除length个字符&#xff0c;然后用param2替换删掉的字符。 示例&#xff1a; select STUFF(abcdefg,1,0,1234) --结果为1234abcdefg select ST…

每日一题163——矩阵置零

给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,1,1],[1,0,1],[1,1,1]] 输出&#xff1a;[[1,0,1],[0,0,0],[1,0,1]] 示例 2&#xff1a; 输入&…

Docker与Docker-compose安装Vulfocus Vulhub漏洞环境

目录 一.docker 和 docker-compose 介绍&#xff1a; docker&#xff1a; docker-compose&#xff1a; 二者的区别&#xff1a; 二者的联系&#xff1a; 二者的总结&#xff1a; 二.Centos 7安装Docker 三.Centos 7安装docker-compose 四.docker-compose搭建Vulhub漏…

Linux安装MySQL后无法通过IP地址访问处理方法

本文主要总结Linux安装Mysql后&#xff0c;其他主机访问不了MySQL数据库的原因和解决方法 环境说明&#xff1a; MySQL 5.7.30CentOS Linux release 7.6.1810 (Core) 创建完Mysql数据库后可以查看mysql 日志获取root 用户登录密码 [rootlocalhost mysql-5.7.30]# cat /var/l…

2 机器学习知识 Softmax回归 deep learning system

机器学习算法的三个主要部分 The hypothesis class: 模型结构loss fuction 损失函数An optimization method&#xff1a;在训练集上减小loss的方法 多分类问题 训练数据&#xff1a; x ( i ) ∈ R n , y ( i ) ∈ 1 , . . . , k f o r i 1 , . . . m x^{(i)}\in \mathbb{R}…

在Fedora-Workstation-Live-x86_64-36-1.5中编译安装信使iptux0.7.6

在Fedora-Workstation-Live-x86_64-36-1.5中编译安装信使iptux0.7.6 https://github.com/iptux-src/iptux/tree/v0.7.6 下载信使iptux-0.7.6.zip&#xff0c;类似飞鸽传书ipmsg&#xff0c;已经尝试过0.8.3版本不成功 [rootfedora ~]# unzip /home/ruhong/download/iptux-0.7…