Python day04 课堂笔记

  今天主要学习了字典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))

猜你喜欢

转载自www.cnblogs.com/if-it-is-possible/p/11432461.html