python元组、字典、集合基础知识笔记

系统管理员 2024-03-23 22:40 149阅读 0赞

元组

Python的元组与列表类似,不同之处在于元组的元素不能修改。元组使用小括号,列表使用方括号。

  1. >>> aTuple = ('et',77,99.9)>>> aTuple
  2. ('et',77,99.9)

一、访问元组

二、修改元组

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

三、count, index

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

  1. >>> a = ('a', 'b', 'c', 'a', 'b')>>> a.index('a', 1, 3) # 注意是左闭右开区间
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. ValueError: tuple.index(x): x not in tuple>>> a.index('a', 1, 4)3>>> a.count('b')2>>> a.count('d')0

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

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

  1. >>> a = (11)>>> a11>>> type(a)
  2. int>>> a = (11,) # 只有一个元素的元组,必须要在元素后写一个逗号>>> a
  3. (11,)>>> type(a)
  4. tuple

五、交换两个变量的值

  1. # 第1种方式,使用中间变量
  2. a = 4
  3. b = 5
  4. c = 0
  5. c = a
  6. a = b
  7. b = c
  8. print(a)
  9. print(b)
  10. # 第2种方式,直接交换。
  11. a, b = 4, 5
  12. a, b = b, a
  13. print(a)
  14. print(b)

字典介绍

一、列表的缺点

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

  1. # 定义一个列表保存,姓名、性别、职业
  2. nameList = ['xiaoZhang', '男', '木匠'];
  3. # 当修改职业的时候,需要记忆元素的下标
  4. nameList[2] = '铁匠'
  5. # 如果列表的顺序发生了变化,添加年龄
  6. nameList = ['xiaoWang', 18, '男', '铁匠']
  7. # 此时就需要记忆新的下标,才能完成名字的修改
  8. nameList[3] = 'xiaoxiaoWang'

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

答:

字典

二、字典的使用

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

变量info为字典类型:

  1. info = {
  2. 'name':'班长', 'id':100, 'sex':'f', 'address':'地球亚洲中国上海'}
  3. info['name'] # 字典使用键来获取对应的值

说明:

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

在习惯上:

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

字典的增删改查

一、查看元素

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

  1. info = {
  2. 'name':'班长','age':18}
  3. print(info['age']) # 获取年龄# print(info['sex']) # 获取不存在的key,会发生异常
  4. print(info.get('sex')) # 获取不存在的key,获取到空的内容,不会出现异常
  5. print(info.get('sex' '男')) # 获取不存在的key, 可以提供一个默认值。

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

二、修改元素

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

demo:

  1. info = {
  2. 'name':'班长', 'id':100}
  3. print('修改之前的字典为 %s:' % info)
  4. info['id'] = 200 # 为已存在的键赋值就是修改
  5. print('修改之后的字典为 %s:' % info)

结果:

  1. 修改之前的字典为 {'name': '班长', 'id': 100}
  2. 修改之后的字典为 {'name': '班长', 'id': 200}

三、添加元素

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

demo:添加新的元素

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

结果:

  1. 添加之前的字典为:{'name': '班长'}
  2. 添加之后的字典为:{'name': '班长', 'id': 100}

四、删除元素

对字典进行删除操作,有一下几种:

  • del
  • clear()

demo:del删除指定的元素

  1. info = {
  2. 'name':'班长', 'id':100}
  3. print('删除前,%s' % info)
  4. del info['name'] # del 可以通过键删除字典里的指定元素
  5. print('删除后,%s' % info)

结果

  1. 删除前,{'name': '班长', 'id': 100}
  2. 删除后,{'id': 100}

del删除整个字典

  1. info = {
  2. 'name':'monitor', 'id':100}
  3. print('删除前,%s'%info)
  4. del info # del 也可以直接删除变量
  5. print('删除后,%s'%info)

结果

  1. 删除前,{'name': 'monitor', 'id': 100}
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. NameError: name 'info' is not defined

clear清空整个字典

  1. info = {
  2. 'name':'monitor', 'id':100}
  3. print('清空前,%s'%info)
  4. info.clear()
  5. print('清空后,%s'%info)

结果

  1. 清空前,{'name': 'monitor', 'id': 100}
  2. 清空后,{}

字典遍历

<1> 遍历字典的key(键)
<2> 遍历字典的value(值)
<3> 遍历字典的项(元素)
<4> 遍历字典的key-value(键值对)

练习

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

    persons = [{

    1. 'name': 'zhangsan', 'age': 18}, {
    2. 'name': 'lisi', 'age': 20}, {
    3. 'name': 'wangwu', 'age': 19},{
    4. 'name': 'jerry', 'age': 21}]

要求让用户输入一个姓名,如果这个姓名在列表里存在,就提示用户名称已存在,添加失败;如果这个姓名在列表里不存在,提示让用户输入年龄,并将用户输入的姓名和年龄添加到这个列表里。

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

参考答案:(使用字典推导式)

  1. dict1 = {
  2. "a": 100, "b": 200, "c": 300}
  3. dict2 = {v: k for k, v in dict1.items()}
  4. print(dict2)

set的使用

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

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

创建格式:

  1. parame = {value01,value02,...}
  2. 或者
  3. set(value)

添加元素

语法格式如下:

  1. s.add(x)

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

  1. >>>thisset = set(("Google", "Runoob", "Taobao"))>>> thisset.add("Facebook")>>> print(thisset)
  2. {
  3. 'Taobao', 'Facebook', 'Google', 'Runoob'}

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

  1. s.update( x )

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

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

移除元素

语法格式如下:

  1. s.remove( x )

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

  1. >>>thisset = set(("Google", "Runoob", "Taobao"))>>> thisset.remove("Taobao")>>> print(thisset)
  2. {
  3. 'Google', 'Runoob'}>>> thisset.remove("Facebook") # 不存在会发生错误
  4. Traceback (most recent call last):
  5. File "<stdin>", line 1, in <module>
  6. KeyError: 'Facebook'
  7. >>>

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

  1. s.discard( x )
  2. >>>thisset = set(("Google", "Runoob", "Taobao"))>>> thisset.discard("Facebook") # 不存在不会发生错误>>> print(thisset)
  3. {
  4. 'Taobao', 'Google', 'Runoob'}

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

  1. s.pop()
  2. thisset = set(("Google", "Runoob", "Taobao", "Facebook"))
  3. x = thisset.pop()
  4. print(x)
  5. print(thisset)

set常见方法列表












































































方法

描述

add()

为集合添加元素

clear()

移除集合中的所有元素

()

拷贝一个集合

pop()

随机移除元素

remove()

移除指定元素

union

返回两个集合的并集

update()

给集合添加元素

difference()

返回多个集合的差集

difference_update()

移除集合中的元素,该元素在指定的集合也存在。

discard()

删除集合中指定的元素

intersection()

返回集合的交集

intersection_update()

删除集合中的元素,该元素在指定的集合中不存在。

isdisjoint()

判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。

issubset()

判断指定集合是否为该方法参数集合的子集。

issuperset()

判断该方法的参数集合是否为指定集合的子集

symmetric_difference()

返回两个集合中不重复的元素集合。

symmetric_difference_update()

移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。

执行字符串

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

  1. x = '1+1'
  2. print(eval(x)) # 2
  3. print(type(eval(x))) # <class 'int'>
  4. y = '{"name":"zhangsan","age":18}'
  5. print(eval(y))
  6. print(type(eval(y))) # <class 'dict'>
  7. print(eval('1 > 2')) # False
  8. eval('input("请输入您的姓名:")')

转换成为字符串

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

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

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

  1. import json
  2. person = {
  3. 'name': 'zhangsan', 'age': 18}
  4. x = json.dumps(person)
  5. print(x) # {"name": "zhangsan", "age": 18}
  6. print(type(x)) # <class 'str'>
  7. nums = [1, 9, 0, 4, 7]
  8. y = json.dumps(nums)
  9. print(y) # [1, 9, 0, 4, 7]
  10. print(type(y)) # <class 'str'>
  11. words = ('hello','good','yes')
  12. z = json.dumps(words)
  13. print(z) # ["hello", "good", "yes"]
  14. print(type(z)) # <class 'str'>

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

  1. x = '{"name": "zhangsan", "age": 18}'
  2. person = json.loads(x)
  3. print(person) # {'name': 'zhangsan', 'age': 18}
  4. print(type(person)) # <class 'dict'>
  5. y = '[1, 9, 0, 4, 7]'
  6. nums = json.loads(y)
  7. print(nums) # [1, 9, 0, 4, 7]
  8. print(type(nums)) # <class 'list'>

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

算数运算符

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
















































运算符

Python 表达式

结果

描述

支持的数据类型

+

[1, 2] + [3, 4]

[1, 2, 3, 4]

合并

字符串、列表、元组

-

{1,2,3,4} - {2,3}

{1,4}

集合求差集

集合

[‘Hi!’] 4

[‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’]

复制

字符串、列表、元组

in

3 in (1, 2, 3)

True

元素是否存在

字符串、列表、元组、字典

not in

4 not in (1, 2, 3)

True

元素是否不存在

字符串、列表、元组、字典

+

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

  1. >>> "hello " + "world"'hello world'>>> [1, 2] + [3, 4]
  2. [1, 2, 3, 4]>>> ('a', 'b') + ('c', 'd')
  3. ('a', 'b', 'c', 'd')

-

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

  1. >>> {
  2. 1, 6, 9, 10, 12, 3} - {
  3. 4, 8, 2, 1, 3}
  4. {
  5. 9, 10, 12, 6}

*

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

  1. >>> 'ab' * 4'ababab'>>> [1, 2] * 4
  2. [1, 2, 1, 2, 1, 2, 1, 2]>>> ('a', 'b') * 4
  3. ('a', 'b', 'a', 'b', 'a', 'b', 'a', 'b')

in

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

  1. >>> 'llo' in 'hello world'True>>> 3 in [1, 2]False>>> 4 in (1, 2, 3, 4)True>>> "name" in {
  2. "name":"chris", "age":18}True

遍历

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

字符串遍历

  1. >>> a_str = "hello world">>> for char in a_str:... print(char,end=' ')
  2. ...
  3. h e l l o w o r l d

列表遍历

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

元组遍历

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

带下标的遍历

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

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

发表评论

表情:
评论列表 (有 0 条评论,149人围观)

还没有评论,来说两句吧...

相关阅读