'''
元组字典集合内置方法与拷贝
'''
# 什么是元组tuple(了解):只可取 不可更改 的列表,元组一创建就被写死了 lt = [1, 2, 3] lt[0] = 2 # 1. 作用:元组一创建就被写死了 # 2. 定义方式:()内用逗号隔开多个元素(可以为任意数据类型) lt = list([1,2,3]) tup = tuple((1, 2, 3)) print(tup, type(tup)) # 如果元组只有一个元素,必须得加逗号 tup1 = (1,) print(tup1, type(tup1)) # 3. 使用方法 # 1. 索引取值 print(tup[0]) # 2. 索引切片 print(tup[0:3]) # 3. for循环 for i in tup: print(i) # 4. 成员运算 print(0 in tup) # 5. len长度 print(len(tup)) # 6. index获取元素索引 print(tup.index(1)) # 7. count 计数 print(tup.count(2)) # 4. 有序or无序 # 有序 # 5. 可变or不可变: 压根不存这一说 # 字符串/列表/字典 --》 常用,他们三个就足够描述时间万物了 # 其他的数据类型可以被替代 --》 列表替代元组,redis数据库替代集合 # 1. 作用: 存储多个数据,对每个数据具有描述 # 2. 定义方式:{}内用逗号隔开多个键key(具有描述意义,不能为可变数据类型):值value(任意数据类型)对 # 散列表(哈希表) dic = {'name': 1} print(dic) dic = {0: '功能1', 1: '功能2'} print(dic) dic = {[1, 2]: 'a'} # 可变==不可哈希,不可变==可哈希 print(dic) dic = {(1,2):'a'} print(dic) # 3. 使用方法 # 优先掌握 # 1. 按key取值/按key修改值 dic = {'a': 1, 'b': 2, 'c': 3} print(dic['a']) dic['b'] = 4 print(dic) # 2. 添加值,没有就添加,有就修改 dic['d'] = 4 print(dic) # 3. for循环 for i in dic: print(i) # 4. 成员运算 print('a' in dic) # 5. len长度 print(len(dic)) # 6. keys/values/items print(dic.keys()) # 看成列表 print(dic.values()) # 获取所有值 print(dic.items()) for i in dic.items(): print(i) for kasdfsad, vsdfsdf in dic.items(): # 解压缩 print(kasdfsad, vsdfsdf) # 需要掌握 # get:获取 s = 'e' print(dic[s]) # KeyError: Nonetype --> s是None,并不是你想象的e print(dic.get('b', 1)) # 字典中没有返回None,可以给定一个默认值 # update : 更新,等同于list里的extend dic1 = {'a': 1, 'c': 2} dic2 = {'b': 1, 'd': 2} dic1.update(dic2) print(dic1) # fromkeys print(dict.fromkeys(dict.fromkeys([1, 2, 3, 4]))) # 默认给None # setdefault # 字典有这个key,就不修改,没有则增加 dic.setdefault('j', 2) dic.setdefault('a', 2) print(dic) # 4. 有序or无序:无序 # 5. 可变or不可变:可变 # 什么是集合:交集/并集/补集/差集 # 1. 作用 : 1。进行上述运算 2. 去重 3.乱序 ---》基于散列表实现的 # 2. 定义方式: {}内以逗号隔开多个元素(不能可为变数据类型) s = {} # 空字典 print(type(s)) s = set() # 空集合 # 上面定义了一个相同的变量但是从未使用,你又定义了这个变量 print(type(s)) inp = input('enter') s = {} if inp > '11': # 字符串比较,先比较第一位数字,然后再比较第二位数字 s +=1 else: print(s) s = {'a', 'a', 'a', 'a', 1, 'v', 2, 2, 'c', 3, 3, 4, 5, 6} # 对于数字而言,不会乱序;但是对于其他,就乱序 print(s) # 3. 使用方法 pythoners = {'jason', 'nick', 'tank', 'sean'} linuxers = {'nick', 'egon', 'kevin'} # 并集 print(pythoners | linuxers) # 交集 print(pythoners & linuxers) # 差集 print(pythoners - linuxers) # 补集 print(pythoners ^ linuxers) # add(*******) pythoners.add('oscar') print(pythoners) pythoners.remove('oscar1') # 没有报错 print(pythoners) pythoners.discard('oscar1') # 没有不报错 print(pythoners) pythoners.pop() # 随机删除一个 print(pythoners) # 4. 有序or无序: 无序 # 5. 可变or不可变:可变 set = {1, 2, 3} print(id(set)) set.add(4) print(id(set)) # 存值个数 # 存一个值:整型/浮点型/字符串 # 存多个值:列表/元组/字典/集合 # 有序or无序 # 有序:字符串/列表/元组(序列类型) # 无序:字典/集合 # 可变or不可变 # 可变:列表/字典/集合 # 不可变:整型/浮点型/字符串/元组 # 拷贝/浅拷贝/深拷贝 --> 只针对可变数据类型 # 主要内容 # 当lt2为lt1的拷贝对象,lt1内部的不可变数据变化,lt2变;lt1内部的可变数据变化,lt2变(*****) # 当lt2为lt1的浅拷贝对象时,lt1内部的不可变元素变化,lt2不变;lt1内部的可变元素变化,lt2变(******) # 当lt2是lt1的深拷贝对象时,lt1内部的不可变类型变化,lt2不变;lt1内部的可变类型变化,lt2不变(*****) 来源:博客园
作者:py哥哥
链接:https://www.cnblogs.com/jinhongquan/p/11529205.html