字典做业及默写

关于set集合做业: 写一个彩票开奖(36选7)
##题意理解:从1-36中随机产生7个不重复的数字做为开奖数字
from random import randintpython

randint(1,36)) #返回1-36之间的一个随机数,包括36

git

 

1,有以下变量(tu是个元祖),请实现要求的功能  服务器

tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])app

    a. 讲述元祖的特性dom

    b. 请问tu变量中的第一个元素 "alex" 是否可被修改?this

    c. 请问tu变量中的"k2"对应的值是什么类型?是否能够被修改?若是能够,请在其中添加一个元素 "Seven"spa

  d. 请问tu变量中的"k3"对应的值是什么类型?是否能够被修改?若是能够,请在其中添加一个元素 "Seven"code

 

2, 字典dic,dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}blog

  a.请循环输出全部的key索引

  b.请循环输出全部的value

    c. 请循环输出全部的key和value

  d. 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典

  e. 请在修改字典中 "k1" 对应的值为 "alex",输出修改后的字典

  f. 请在k3对应的值中追加一个元素 44,输出修改后的字典

  g. 请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典

 

3,av_catalog = {
    "欧美":{
        "www.youporn.com": ["不少免费的,世界最大的","质量通常"],
        "www.pornhub.com": ["不少免费的,也很大","质量比yourporn高点"],
        "letmedothistoyou.com": ["可能是自拍,高质量图片不少","资源很少,更新慢"],
        "x-art.com":["质量很高,真的很高","所有收费,屌丝请绕过"]
    },
    "日韩":{
        "tokyo-hot":["质量怎样不清楚,我的已经不喜欢日韩范了","verygood"]
    },
    "大陆":{
        "1024":["所有免费,真好,好人一辈子平安","服务器在国外,慢"]
    }
}

    a,给此 ["不少免费的,世界最大的","质量通常"]列表第二个位置插入一个  元素:'量很大'。
    b,将此 ["质量很高,真的很高","所有收费,屌丝请绕过"]列表的 "所有收费,屌丝请绕过" 删除。
    c,在 ["质量很高,真的很高","所有收费,屌丝请绕过"]列表中添加"金老板最喜欢这个"。
    d,将此["质量怎样不清楚,我的已经不喜欢日韩范了","verygood"]列表的 "verygood"所有变成大写。

  e,给'大陆' 对应的字典添加一个键值对 '1048' :['一天就封了']

    f,删除此"letmedothistoyou.com": ["可能是自拍,高质量图片不少","资源很少,更新慢"]键值对。

    g,给此["所有免费,真好,好人一辈子平安","服务器在国外,慢"]列表的第一个元素,加上一句话:'能够爬下来'

 

四、有字符串 "k:1|k1:2|k2:3|k3:4" 处理成字典 {'k':1,'k1':2....}  (升级题)

 

五、元素分类

有以下值li= [11,22,33,44,55,66,77,88,99,90],将全部大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。

即: {'k1': 大于66的全部值列表, 'k2': 小于66的全部值列表}

 

六、输出商品列表,用户输入序号,显示用户选中的商品(升级题)   

商品列表:

 goods = [{"name": "电脑", "price": 1999},
         {"name": "鼠标", "price": 10},
         {"name": "游艇", "price": 20},
         {"name": "美女", "price": 998}, ]

 

要求:

1:页面显示 序号 + 商品名称 + 商品价格,如:

       1 电脑 1999

       2 鼠标 10

      …

2:用户输入选择的商品序号,而后打印商品名称及商品价格

3:若是用户输入的商品序号有误,则提示输入有误,并从新输入。

4:用户输入Q或者q,退出程序。

 

 

明日默写内容。

 

1)字典的增删改查。

2)过滤敏感字符代码的默写。

 

li = ["苍老师","东京热","武藤兰","波多野结衣"]

comment = input('请输入评论>>>')
for i in li:
    if i in comment:
        comment = comment.replace(i,'*'*len(i))
print(comment)

 

#!/Users/liangyufeng/venv/bin/python3
# _*_ coding:utf-8 _*_

##课上留的做业
# 关于set集合做业: 写一个彩票开奖(36选7)
##题意理解:从1-36中随机产生7个不重复的数字做为开奖数字
from random import randint
nums = set()
#下面是相同的思想,不一样的代码堆砌方式
#方法1
while True:
    nums.add(randint(1,36)) #返回1-10之间的一个随机数,包括10
    if len(nums) == 7:
        break
print(nums)
#方法2
while len(nums) != 7:  # 或者<7
    nums.add(randint(1,36))
print(nums)

#老师讲的,其实仍是同样的思想
while len(nums) < 7:  # 或者<7
    nums.add(randint(1, 36))
print(nums)

'''
for 和 while 的使用场合:
for : 肯定循环范围或次数的用for. str, list, dic, tuple, set
while: 不肯定循环次数的用 while.(while 能够无限循环,而 for 必定要给个循环的边界)

'''

# day5做业及默写
#
# 1,有以下变量(tu是个元祖),请实现要求的功能
#
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])
#     a. 讲述元祖的特性

        # 元组最大的特性就是元组的不可变: 指的是对内部元素的指向不变,若是内部的元素是可变的数据类型,则照样是可变的,这个和元组的不可变没有冲突.

#     b. 请问tu变量中的第一个元素 "alex" 是否可被修改?不能够
#     c. 请问tu变量中的"k2"对应的值是什么类型?是否能够被修改?若是能够,请在其中添加一个元素 "Seven"
tu[1][2]['k2'].append("Seven")#列表,能够修改
# d. 请问tu变量中的"k3"对应的值是什么类型?是否能够被修改?若是能够,请在其中添加一个元素 "Seven"
# 元组,不能够修改


# 2, 字典dic,
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
# a.请循环输出全部的key
for k in dic:
    print(k)
# b.请循环输出全部的value
for v in dic.values():
    print(v)
# c. 请循环输出全部的key和value
for k,v in dic.items():
    print(k,v)
# d. 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典
dic["k4"] = "v4"
# e. 请在修改字典中 "k1" 对应的值为 "alex",输出修改后的字典
dic["k1"] = "alex"

# f. 请在k3对应的值中追加一个元素 44,输出修改后的字典
dic["k3"].append(44)
print(dic)
# g. 请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典
dic["k3"].insert(1,18)
print(dic)


# 3,
av_catalog = {
    "欧美":{
        "www.youporn.com": ["不少免费的,世界最大的","质量通常"],
        "www.pornhub.com": ["不少免费的,也很大","质量比yourporn高点"],
        "letmedothistoyou.com": ["可能是自拍,高质量图片不少","资源很少,更新慢"],
        "x-art.com":["质量很高,真的很高","所有收费,屌丝请绕过"]
    },
    "日韩":{
        "tokyo-hot":["质量怎样不清楚,我的已经不喜欢日韩范了","verygood"]
    },
    "大陆":{
        "1024":["所有免费,真好,好人一辈子平安","服务器在国外,慢"]
    }
}
#
# a,给此 ["不少免费的,世界最大的","质量通常"]列表第二个位置插入一个  元素:'量很大'。
av_catalog["欧美"]["www.youporn.com"].insert(2,'量很大')
# b,将此 ["质量很高,真的很高","所有收费,屌丝请绕过"]列表的 "所有收费,屌丝请绕过" 删除。
av_catalog["欧美"]["x-art.com"].remove("所有收费,屌丝请绕过")
av_catalog["欧美"]["x-art.com"].pop(1)
# c,在此 ["质量很高,真的很高","所有收费,屌丝请绕过"]列表中添加"金老板最喜欢这个"。
av_catalog["欧美"]["x-art.com"].append("金老板最喜欢这个")
# d,将此["质量怎样不清楚,我的已经不喜欢日韩范了","verygood"]列表的 "verygood"所有变成大写。
av_catalog["日韩"]["tokyo-hot"][1] = av_catalog["日韩"]["tokyo-hot"][1].upper()#字符串不可变,改完以后要塞回去##这里千万不要忘记
# e,给'大陆' 对应的字典添加一个键值对 '1048' :['一天就封了']
av_catalog["大陆"]["1048"] = ['一天就封了']
# f,删除此"letmedothistoyou.com": ["可能是自拍,高质量图片不少","资源很少,更新慢"]键值对。
av_catalog["欧美"].pop("letmedothistoyou.com")
del av_catalog["欧美"]["letmedothistoyou.com"]
# g,给此["所有免费,真好,好人一辈子平安","服务器在国外,慢"]列表的第一个元素,加上一句话:'能够爬下来'
av_catalog["大陆"]["1024"].insert(0,'能够爬下来')##老师是做为 insert这样讲的,可是我以为这里有歧义,这里的表述是对第一个元素,而不是对第一个位置


##须要记忆
# 四、有字符串 "k:1|k1:2|k2:3|k3:4" 处理成字典 {'k':1,'k1':2....}  (升级题)
dic = {}
s = "k:1|k1:2|k2:3|k3:4"
for el in s.split('|'):  #['k:1','k1:2','k2:3,'k3:4']
    k, v = el.split(':') #解构   k,v = el[0],el[-1]
    dic[k] = int(v)
print(dic)

#老师的更详细
s = 'k:1|k1:2|k2:3|k3:4'
lst = s.split('|')
# print(lst)  #['k:1', 'k1:2', 'k2:3', 'k3:4']
dic = {}
for item in lst:
    # print(item) # k:1  k1:2 k2:3 k3:4
    k,v = item.split(':') #['k','1']
    dic[k] = int(v)
print(dic)


##要理解记忆
# 五、元素分类
# 有以下值li= [11,22,33,44,55,66,77,88,99,90],将全部大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。
# 即: {'k1': 大于66的全部值列表, 'k2': 小于66的全部值列表}
li= [11,22,33,44,55,66,77,88,99,90]
# 方法一
dic = {'k1': [], 'k2': []} # 这里直接定义了字典中的全部键值对,有一个缺点是若是题目要将值分到更多的键值对中要写不少,很麻烦,无论是本身开始就定义好仍是以后本身手加新的键值对
for i in li:
    if i > 66:
        dic['k1'].append(i)
    elif i < 66:
        dic['k2'].append(i)
print(dic)
#
#方法二 利用字典的 get 方法,当键不存在时候返回None,是False
dic = {}
for item in li:
    if item > 66:
        if dic.get('key1'):  # key1 存在直接添加元素
            dic['key1'].append(item)
        else:
            dic['key1'] = [item]  # key1不存在建立并添加元素(实际上是建立一个带元素的列表)
    elif item < 66:
            if dic.get('key2'):  # key2 存在直接添加元素
                dic['key2'].append(item)
            else:
                dic['key2'] = [item]  # key2不存在建立并添加元素

# 方法三 这个方法要记忆 利用 setdefault 方法的查询和添加功能
dic = {}
for item in li:
    if item > 66:
        #首先判断 key1是否存在.一开始是不存在的,根据 key1将[]添加到字典中,而后执行查询操做返回[],再执行 append()
        #第二次走到这里,直接根据 key1查询出列表,就执行 append()
        dic.setdefault('key1', []).append(item)
    elif item < 66:
        dic.setdefault('key2', []).append(item)

print(dic)


# 六、输出商品列表,用户输入序号,显示用户选中的商品(升级题)
# 商品列表:
# goods = [{"name": "电脑", "price": 1999},
#      {"name": "鼠标", "price": 10},
#      {"name": "游艇", "price": 20},
#      {"name": "美女", "price": 998}, ]

# 要求:
# 1:页面显示 序号 + 商品名称 + 商品价格,如:
#           1 电脑 1999
#                2 鼠标 10
#
# 2:用户输入选择的商品序号,而后打印商品名称及商品价格
# 3:若是用户输入的商品序号有误,则提示输入有误,并从新输入。
# 4:用户输入Q或者q,退出程序。

#我写的
goods = [{"name": "电脑", "price": 1999},
     {"name": "鼠标", "price": 10},
     {"name": "游艇", "price": 20},
     {"name": "美女", "price": 998}, ]
while 1:
    for i in range(len(goods)):
        print('%s %s %s'%(i+1,goods[i]['name'],goods[i]['price']))
    num = input('请输入要选择的商品序号(Q退出程序):').strip()
    if num.isdigit():
        num = int(num)
        if num < len(goods):
            print('%s %s'%(goods[num-1]['name'],goods[num-1]['price']))
        else:
            print('商品序号有误,请从新输入')
    elif num.upper() == 'Q':
        break
    else:
        print('输入有误,请从新输入')

#老师讲解的,想法没差,就看代码的具体实现
goods = [{"name": "电脑", "price": 1999},
         {"name": "鼠标", "price": 10},
         {"name": "游艇", "price": 20},
         {"name": "美女", "price": 998}]

for i in range(len(goods)):
    good = goods[i]  # {"name": "电脑", "price": 1999}
    print(i+1, good['name'], good['price'])


while 1:
    content = input('请输入你要选择的商品的序号:')
    if content.upper() == "Q":
        print("结束购物")
        break
    # 判断若是输入的不是数字 或者超过了商品的序号范围
    if not content.isdigit() or int(content) > len(goods) or int(content) <= 0:
        print("对不起, 您输入的内容有误. 请从新输入")
        continue # 从新执行循环
    num = int(content) # 转换成数字
    # 还原索引
    index = num - 1
    good = goods[index] # 根据索引找到你购买的商品  {"name": "美女", "price": 998}
    print(f"您要购买的商品名称是{good['name']}, 商品的价格是{good['price']}")




# 明日默写内容。
#
# 1)字典的增删改查。
'''
        1. 添加
            dic[新key] = 值

            setdefault(key,value) key不存在,添加键值对
        2. 删除
            pop(key) 删除指定键的键值对
            ## dic.popitem() # 随机删除一项(如今的版本通常是弹出最后一项)
            ##del dic["李安"]  
            ##dic.clear() # 清空
        3. 修改
            dic[老key] = (新)值
            update() 更新字典(迭代更新,相似于列表的 extend)
        4. 查询
            dic[key]  ##直接使用key就能够拿到value
            get(key, 值) ##当key不存在. 返回第二个参数. 默认第二个参数是None
            setdefault(key, value)  key存在,返回对应的 value,key 不存在,先新增,再返回对应的 value
        5. 遍历
        # 1. 使用for循环直接遍历字典的key
        # for key in dic:
        #     print(key)
        #     print(dic[key])
        
        # 2. 可使用字典的items()+解构能够直接获取到key和value
        # for k, v in dic.items():
        #     print(k)
        #     print(v)
'''

# 2)过滤敏感字符代码的默写。

li = ["苍老师","东京热","武藤兰","波多野结衣"]

comment = input('请输入评论>>>')
for i in li:
    if i in comment:
        comment = comment.replace(i,'*'*len(i))
print(comment)
相关文章
相关标签/搜索