今天主要学习了字典dict的一些相关知识。在开始今天内容之前,我们需要了解下数据类型的划分问题。
1.数据类型的划分:
#数据类型划分:可变数据类型 和 不可变数据类型 # 1.不可变数据类型:元祖('儿子'绝对是不能更改的),bool ,int , str 可哈希(hash) # 2.可变数据类型:list , dict,set 不可哈希 # #dict是唯一的映射类型,是以键值对形式存在, # #dict key : 必须是不可变数据类型,可哈希。 # #dict value :任意数据类型 # # dict 优点:二分查找去查询,储存大量的关系型数据 # 特点:无序的,( Python 3.6X 以后开始排序。) 说明没有索引,需要通过键值对的形式开始查找
讲解字典我们从增删改查四个方面来讲解:
1.增加:
# dic = { # 'name':['大猛','小孟'], # 'py9':[{'num':71,'avg_age':18,}, # {'num': 71, 'avg_age': 18, }, # {'num': 71, 'avg_age': 18, }, # ], # True:1, # (1,2,3):'wuyiyi', # 2:'二哥', # } # print(dic) dic1 = {'age': 18, 'name': 'jin', 'sex': 'male',} #增: # dic1['high'] = 185 #没有键值对,添加 # dic1['age'] = 16 #如果有键,则值覆盖 # dic1.setdefault('weight') # 有键值对,不做任何改变,没有才添加。 # dic1.setdefault('weight',150) # dic1.setdefault('name','二哥') # print(dic1)
2.删除:
#删 # print(dic1.pop('age')) # 有返回值,按键去删除 # print(dic1.pop('二哥',None)) # 可设置返回值 # print(dic1) # print(dic1.popitem()) # 随机删除 有返回值 元组里面是删除的键值。 # # print(dic1) # del dic1['name1'] # print(dic1) # del dic1 # print(dic1)
3.修改:
#改 update # dic1['age'] = 16 # dic = {"name":"jin","age":18,"sex":"male"} # dic2 = {"name":"alex","weight":75} # dic2.update(dic) # # # print(dic) # print(dic2) dic1 = {'age': 18, 'name': 'jin', 'sex': 'male',}
4.查询:
#查 # print(dic1.keys(),type(dic1.keys())) # print(dic1.values()) # print(dic1.items()) # for i in dic1: # print(i) # for i in dic1.keys(): # print(i) # for i in dic1.values(): # print(i) # a,b = 1,2 # print(a,b) # a = 1 # b = 2 # a,b = b,a # print(a,b) # a,b = [1,2],[2,3] # a,b = (1,2) # print(a,b) # for k,v in dic1.items(): # print(k,v) # v1 = dic1['name'] # print(v1) # v2 = dic1['name1'] # 报错 # print(v2) # print(dic1.get('name1','没有这个键'))
字典的嵌套:
dic = { 'name':['alex','wusir','taibai'], 'py9':{ 'time':'1213', 'learn_money':19800, 'addr':'CBD', }, 'age':21 } # dic['age'] = 56 # print(dic['name']) # dic['name'].append('ritian') # l = [1,2,'wusir'] # l[2] = l[2].upper() # dic['name'][1] = dic['name'][1].upper() # print(dic) #female : 6 # dic['py9']['female'] = 6 # print(dic)
下面是作业习题:
# #1.写代码,有如下列表,按照要求实现每一个功能 # li = ['alex','wusir','eric','rain','alex'] # #1)计算列表的长度并输出 # print(len(li)) # #2)列表中追加元素‘seven’,并输出添加后的列表 # li.append('seven') # print(li) # #3)请在列表的第一个位置插入元素‘Tony’,并输出添加后的列表 # li.insert(0,'Tony') # print(li) # #4)请修改列表第二个位置的元素为‘Kelly’,并输出修改后的列表 # li[1] = 'Kelly' # print(li) # #5)请将列表 l2 =[1,'a',3,4,'heart']的每一个元素添加到列表li中,一行代码实现 # # 不允许循环添加 # l2 =[1,'a',3,4,'heart'] # li.extend(l2) #extend 迭代 !!1 # print(li) # #6)请将字符串 s = 'qwert'的每一个元素添加到列表li中,一行代码实现,不允许循环添加。 # s = 'qwert' # li.extend(s) # print(li) # #7)请删除列表中元素'eric',并输出添加后的列表 # #remove通过元素删除 # li.remove('eric') # print(li) # #8)请删除列表中的第二个元素,并输出删除的元素和删除元素后的列表 # li.pop(1) # print(li.pop(1)) # print(li) # #9)请删除列表中的第2至4个元素,并输出删除元素后的列表。 # #!!! # del li [1:4] # print(li) # #10)请将列表所有的元素反转,并输出反转后的列表 # li.reverse() # print(li) # #11)请计算出'alex'元素在列表li中出现的次数,并输出该次数。 # a = li.count('alex') # print(a) # # 2.写代码,有如下列表,利用切片实现每一个功能 # li = [1,3,2,'a',4,'b',5,'c'] # # 1)通过对li列表的切片形成新的列表l1,l1={1,3,2} # l1 = li[0:3] # print(l1) # # 2)通过对li列表的切片形成新的列表l2,l2={'a',4,'b'} # l2 = li[3:6] # print(l2) # # 3)通过对li列表的切片形成新的列表l3,l3={1,2,4,5} # l3 = li[0:7:2] # print(l3) # # 4)通过对li列表的切片形成新的列表l4,l4={3,'a',b} # l4 = li[1:6:2] # print(l4) # # 5)通过对li列表的切片形成新的列表l5,l5={'c'} # l5 = li[-1] # print(l5) # # 6)通过对li列表的切片形成新的列表l6,l6={'b','a',3} # l6 = li[-3:0:-2] # print(l6) #3.写代码,有如下列表,按照要求实现每一个功能 #lis = [2,3,'k',['qwe',20,['k1',['tt',3,'l']],89],'ab','adv'] #1.将列表lis中的'tt'变成大写(用两种方法) # lis[3][2][1][0] = lis[3][2][1][0].upper() # print(lis) # lis[3][2][1][0] = str(lis[3][2][1][0]).replace('tt','TT') # print(lis) #2.将列表中的数字3变成字符串'100'(用两种方法) # lis[1] = '100' # print(lis) # lis[1] = str(lis[1]).replace(str(3),'100') # print(lis) #3.将列表中的字符串'l'变成数字101(用两种方法) # lis[3][2][1][2] = 101 # print(lis) # lis[3][2][1][2] = str(lis[3][2][1][2]).replace('1',str(101)) # print(lis) #4.请用代码实现: # li = {'alex','eric','rain'} # 利用下划线将列表的每一个元素拼接成字符串"alex_eric_rain" # li = {'alex','eric','rain'} # s1 = '_'.join(li) # print(s1) # 5,查找列表li中的元素,移除每个元素的空格, # 并找出以’A’或者’a’开头,并以’c’结尾的所有元素, # 并添加到一个新列表中,最后循环打印这个新列表。 # li = [‘taibai ’,’alexC’,’AbC ’,’egon’,’ Ritian’,’ Wusir’,’ aqc’] # li = [ 'taibai' , 'alexC' , 'ABC' , 'egon' ,'Ritian ',' Wusir',' aqc'] # b = [] # for i in li: # s = i.strip() # if s.startswith('A')== True or s.startswith('a') == True and s.endswith('c') == True : # b.append(s) # else: # continue # for x in b: # print(x) # 6、开发敏感词语过滤程序,提示用户输入评论内容,如果用户输入的内容中包含特殊的字符: # 敏感词列表 li = ["苍老师","东京热",”武藤兰”,”波多野结衣”] # 则将用户输入的内容中的敏感词汇替换成***,并添加到一个列表中; # 如果用户输入的内容没有敏感词汇,则直接添加到上述的列表中。 # li=["苍老师","东京热","武藤兰","波多野结衣"] # new_li= [] # info = input("评论") # 苍老师,东京热 法律框架第三 # for i in li: # if i in info: # l = len(i) # info=info.replace(i,'*'*l) # new_li.append(info) # print(new_li)
#输入一个字符串,求出其出现数字字符的个数 #eg. # fhdklah123rfdj12fdjsl3 ' 123 12 13' # info = input('>>>').strip() # for i in info: # if i.isalpha(): # info = info.replace(i," ") # l = info.split() # print(len(l))