zoukankan      html  css  js  c++  java
  • 铁乐学python_day05-作业

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

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

    a. 讲述元祖的特性

    答:
    1)元祖tuple是一个只读列表,只可以查看,不可以修改增加和删除;
    2)在定义只有一个元素的元祖时,要加上逗号以示和小括号的区别,如 age = (18, )

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

    答:不可以,它直接属于元组tu的元素。

    c. 请问tu变量中的"k2"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 “Seven”

    答:"k2"对应的值是列表类型;列表里面的元素可以被修改。

    tu[1][2]['k2'].append('Seven')
    print(tu)
    
    效果:
    ('alex', [11, 22, {'k2': ['age', 'name', 'Seven'], 'k1': 'v1', 'k3': (11, 22, 33)}, 44])
    

    d. 请问tu变量中的"k3"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 “Seven”

    答:"k3"对应的值是元组类型,不可以被修改。
    强行修改会报错,告诉你元祖类型的对象没有append的方法。
    如:

    tu[1][2]['k3'].append('Seven')
    AttributeError: 'tuple' object has no attribute 'append'
    # 不过作为键值,k3对应的值倒可以被直接替换成另一个元祖数据,例如:
    # tu[1][2]['k3'] = (11, 22, 33, 'Seven' )
    # print(tu)
    # 会显示出有Seven在的新元祖。
    

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

    a. 请循环输出所有的key
    dic = {'k1': "v1", "k2": "v2", "k3": [11, 22, 33]}
    for i in dic:print(i)
    
    b. 请循环输出所有的value
    for i in dic.values():
        print(i)
    
    c. 请循环输出所有的key和value
    for i in dic.items():
        print(i)
    
    d. 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典
    dic['k4'] ='v4'
    print(dic)
    
    效果:
    {'k2': 'v2', 'k3': [11, 22, 33], 'k4': 'v4', 'k1': 'v1'}
    
    e. 请在修改字典中 “k1” 对应的值为 “alex”,输出修改后的字典
    dic['k1'] = 'alex'
    print(dic)
    
    效果:
    {'k2': 'v2', 'k1': 'alex', 'k3': [11, 22, 33]}
    
    f. 请在k3对应的值中追加一个元素 44,输出修改后的字典
    dic['k3'].append(44)
    print(dic)
    
    效果:
    {'k2': 'v2', 'k3': [11, 22, 33, 44], 'k1': 'v1'}
    
    g. 请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典
    dic['k3'].insert(0, 18)
    print(dic)
    
    效果:
    {'k3': [18, 11, 22, 33], 'k2': 'v2', 'k1': 'v1'}
    
    3,av_catalog = {
        "欧美":{
            "www.youporn.com": ["很多免费的,世界最大的","质量一般"],
            "www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
            "letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
            "x-art.com":["质量很高,真的很高","全部收费,屌丝请绕过"]
        },
        "日韩":{
            "tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","verygood"]
        },
        "大陆":{
            "1024":["全部免费,真好,好人一生平安","服务器在国外,慢"]
        }
    }
    
    	# 1,给此 ["很多免费的,世界最大的","质量一般"]列表第二个位置插入一个元素:'量很大'。
      print(av_catalog['欧美']['www.youporn.com'])
      av_catalog['欧美']['www.youporn.com'].insert(1,'量很大')
      print(av_catalog['欧美']['www.youporn.com'])
    
      效果对比:
      ['很多免费的,世界最大的', '质量一般']
      ['很多免费的,世界最大的', '量很大', '质量一般']
    
    	# 2,将此 ["质量很高,真的很高","全部收费,屌丝请绕过"]列表的 "全部收费,屌丝请绕过" 删除。
    	print(av_catalog['欧美']['x-art.com'])
      av_catalog['欧美']['x-art.com'].pop()
      print(av_catalog['欧美']['x-art.com'])
      
      效果对比:
      ['质量很高,真的很高', '全部收费,屌丝请绕过']
      ['质量很高,真的很高']
    
    	# 3,将此 ["质量很高,真的很高","全部收费,屌丝请绕过"]列表的 "全部收费,屌丝请绕过" 删除。
      同上
    
    	# 4,将此["质量怎样不清楚,个人已经不喜欢日韩范了","verygood"]列表的 "verygood"全部变成大写。
      print(av_catalog['日韩']['tokyo-hot'])
      av_catalog['日韩']['tokyo-hot'][1] = av_catalog['日韩']['tokyo-hot'][1].upper()
      print(av_catalog['日韩']['tokyo-hot'])
      
      效果对比:
      ['质量怎样不清楚,个人已经不喜欢日韩范了', 'verygood']
      ['质量怎样不清楚,个人已经不喜欢日韩范了', 'VERYGOOD']
    
    	# 5,给 '大陆' 对应的字典添加一个键值对 '1048' :['一天就封了']
    	print(av_catalog['大陆'])
      av_catalog['大陆'].setdefault('1048',['一天就封了'])
      print(av_catalog['大陆'])
      
      效果对比:
      {'1024': ['全部免费,真好,好人一生平安', '服务器在国外,慢']}
      {'1048': ['一天就封了'], '1024': ['全部免费,真好,好人一生平安', '服务器在国外,慢']}
    
    	# 6,删除此"letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"]键值对。
      av_catalog['欧美'].pop('letmedothistoyou.com')
      print('letmedothistoyou.com' in av_catalog['欧美'])
      返回的值是False,证明删除了。
    
    	# 7,给此["全部免费,真好,好人一生平安","服务器在国外,慢"]列表的第一个元素,加上一句话:'可以爬下来'
    	print(av_catalog['大陆']['1024'][0])
      av_catalog['大陆']['1024'][0] = av_catalog['大陆']['1024'][0] + '可以爬下来'
      可以简写成 av_catalog['大陆']['1024'][0] += '可以爬下来' (和count += 1,自增一样)
      print(av_catalog['大陆']['1024'][0])
      
      显示对比:
      全部免费,真好,好人一生平安
      全部免费,真好,好人一生平安可以爬下来
    

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

    k = "k:1|k1:2|k2:3|k3:4"
    dk = { }
    for i in k.strip().split('|'):
        i = i.stsrip().split(':')
        # print(i) 调试用,
        # i[0]之类己经是直接指代字符串了,不需要再加''引住。i[1]注意要int转换成整数型。
        dk.setdefault(i[0], int(i[1]))
    print(dk)
    
    参考
    s = 'k:1|k1:2|k2:3|k3:4'
    dic = {}
    for i in s.strip().split('|'):
        i = i.stsrip().split(':')
    dic[i[0].strip()] = int(i[1])
    print(dic) 
    
    结果:
    {'k2': 3, 'k1': 2, 'k3': 4, 'k': 1}
    

    5、元素分类

    有如下值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 = { }
    l1 = [ ]
    l2 = [ ]
    for i in li:
        if i > 66:
            l1.append(i)
        if i < 66:
            l2.append(i)
    #print(l1, l2)
    dic.setdefault('k1', l1)
    dic.setdefault('k2', l2)
    print(dic)
    
    效果:
    {'k2': [11, 22, 33, 44, 55], 'k1': [77, 88, 99, 90]}
    
    参考:
    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)
        if i < 66:
            dic['k2'].append(i)
    print(dic)
    
    扩展:(直接在for循环里实施添加,而不是提前生成了一个字典)
    li = [11, 22, 33, 44, 55, 77, 88, 99, 90]
    result = {}
    for row in li:
        result.setdefault('k1', [])
        result.setdefault('k2', [])
        if row > 66:
            result['k1'].append(row)
        if row < 66:
            result['k2'].append(row)
    print(result)
    

    6、输出商品列表,用户输入序号,显示用户选中的商品
    商品 li = ["手机", "电脑", '鼠标垫', '游艇']
    要求:1:页面显示 序号 + 商品名称,如:
    1 手机
    2 电脑

    2: 用户输入选择的商品序号,然后打印商品名称
    3:如果用户输入的商品序号有误,则提示输入有误,并重新输入。
    4:用户输入Q或者q,退出程序。

    li = ["手机", "电脑", '鼠标垫', '游艇']
    while True:
    for i in range(len(li)):
        	   print(str(i+1) + ' ' + li[i])
        sn = input('选择商品序号(按Q/q回车退出):').strip().upper()
        if sn == 'Q':
            print("请慢走")
            break
        if not sn.isdigit() or int(sn) > len(li):
            print('请重新输入正确的商品序列号:')
            continue
        print(li[int(sn)-1])
    
    上面的考虑还不够周全,没有考虑到输入0的情况。
    参考:
    li = ["手机", "电脑", '鼠标垫', '游艇']
    while True:
        for i in li:
            print('{}	{}'.format(li.index(i)+1, i)) #格式化输出,中间多了个空格符
        num = input('请输入商品序号:q/Q退出' ).strip()
        if num.isdigit():
            num = int(num)
            if num > 0 and num <= len(li):
                print(li[num - 1])
            else:
                print('你输入的选项超出范围,请重新输入')
        elif num.upper() == 'Q':break
        else:
    	    print('输入的有非法数字,请重新输入')
    

    明日默写内容。
    1)字典的增删改查。
    增:1) dict['key'] = 'value' 有则覆盖,无则添加
    2) dict.setdefault('key', 'value') 有则不改,无则添加
    删:1) dict.pop('key') 通过键删除值
    2) dict.clear() 清空字典
    3)del dict['key'] 通过键删除键值对
    del dict 删除字典
    4)dict.popitem() 随机删除
    改 1)dict['key'] = 'value' 和增的第一种方法一样,直接修改键来变动值
    2)dict.update(dict2) 将dict2键/值对,更新(覆盖有的,无的添加)到dict
    查 1)dict['key'] 通过键返回的是你要查的值,但是要注意的是若没有查询的键会报错。
    2)dict.get('key',default=None) 同样通过键查值,但用这个查没有的键时返回的是自定义的值。
    3)dict.keys() 以列表方式返回字典中所有的键。
    4)dict.values() 以列表方式返回字典中所有的值。
    5)dict.items() 以列表方式返回可遍历的键值对。分别成对放在元组中。

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

    li = ["苍老师","东京热","武藤兰","波多野结衣"]
    l1 = []
    comment = input('请输入评论>>>')
    for i in li:
        if i in comment:
            comment = comment.replace(i,'*'*len(i))
    l1.append(comment)
    print(l1)
    

    end
    2018-3-22

  • 相关阅读:
    做题总结
    关于SQLSERVER中用SQL语句查询的一些个人理解
    关于SQLSERVER联合查询一点看法
    C#中怎样实现序列化和反序列化
    java内部类的使用
    C#抽象类
    匿名类
    Foreach能够循环的本质
    C#索引器
    深入了解接口的使用
  • 原文地址:https://www.cnblogs.com/tielemao/p/8638815.html
Copyright © 2011-2022 走看看