zoukankan      html  css  js  c++  java
  • python学习内容.05

    本节主要内容:
    1. 字典的简单介绍 2. 字典增删改查和其他操作 3. 字典的嵌套
    一. 字典的简单介绍    字典(dict)是python中唯一的一个映射类型.他是以{ }括起来的键值对组成. 在dict中key是唯一的. 在保存的时候, 根据key来计 算出一个内存地址. 然后将key-value保存在这个地址中. 这种算法被称为hash算法, 所以, 切记, 在dict中存储的key-value中的 key'必须是可hash的, 如果你搞不懂什么是可哈希, 暂时可以这样记, 可以改变的都是不可哈希的, 那么可哈希就意味着不可变. 这个是为了能准确的计算内存地址而规定的.
    已知的可哈希(不可变)的数据类型: int, str, tuple, bool 不可哈希(可变)的数据类型: list, dict, set
    语法 :    {key1: value1, key2: value2....}
    注意: key必须是不可变(可哈希)的. value没有要求.可以保存任意类型的数据
    # 合法 dic = {123: 456, True: 999, "id": 1, "name": 'sylar', "age": 18, "stu": ['帅哥', '美女'], (1, 2, 3): '麻花藤'} print(dic[123]) print(dic[True]) print(dic['id']) print(dic['stu']) print(dic[(1, 2, 3)]) # 不合法 # dic = {[1, 2, 3]: '周杰伦'}   # list是可变的. 不能作为key # dic = {{1: 2}: "哈哈哈"}     # dict是可变的. 不能作为key dic = {{1, 2, 3}: '呵呵呵'}    # set是可变的, 不能作为key
    dict保存的数据不是按照我们添加进去的顺序保存的. 是按照hash表的顺序保存的. 而hash表不是连续的. 所以不能进行切片工作. 它只能通过key来获取dict中的数据
    二. 字典的增删改查和其他相关操作   
    1. 增加
    dic = {} dic['name'] = '周润发'     # 如果dict中没有出现这个key, 就会新增一个key-value的组合进dict dic['age'] = 18 print(dic)
    # 如果dict中没有出现过这个key-value. 可以通过setdefault设置默认值 dic.setdefault('李嘉诚')   # 也可以往里面设置值. dic.setdefault("李嘉诚", "房地产")    # 如果dict中已经存在了. 那么setdefault将不会起作用
    print(dic)
    2. 删除
    ret = dic.pop("jay") print(ret)
    del dic["jay"] print(dic)
    # 随机删除. ret = dic.popitem()
    # 清空字典中的所有内容 dic.clear()
    3. 修改
    dic = {"id": 123, "name": 'sylar', "age": 18} dic1 = {"id": 456, "name": "麻花藤", "ok": "wtf"} dic.update(dic1)    # 把dic1中的内容更新到dic中. 如果key重名. 则修改替换. 如果不存在key, 则新增. print(dic) print(dic1)
    4. 查询
            查询一般用key来查找具体的数据.
     print(dic['name']) # print(dic['sylar'])     # 报错 print(dic.get("ok")) print(dic.get("sylar"))      # None print(dic.get("sylar", "牛B"))   # 牛B
    5. 其他相关操作
     
    dic = {"id": 123, "name": 'sylar', "age": 18, "ok": "科比"}
    print(dic.keys())   # dict_keys(['id', 'name', 'age', 'ok']) 不用管它是什么.当成list来用就行 for key in dic.keys():    print(key)
    print(dic.values())     # dict_values([123, 'sylar', 18, '科比']) 一样. 也当list来用 for value in dic.values():    print(value)
    print(dic.items())  # dict_items([('id', 123), ('name', 'sylar'), ('age', 18), ('ok', '科比')]) 这个东西也是list. 只不过list中装的是tuple for key, value in dic.items():  # ?? 这个是解构    print(key, value)
    # 解构 a, b = 1, 2 print(a, b)
    (c, d) = 3, 4 print(c, d)
    e, f = [1, 2, 3]    # 解构的时候注意数量必须匹配 print(e, f)
    三. 字典的嵌套 # 字典的嵌套 dic1 = {    "name": "汪峰",    "age": 18,    "wife": {        "name": '章子怡',        "age": 28    },    "children": ['第一个毛孩子', '第二个毛孩子'],    "desc": '峰哥不会告我吧. 没关系. 我想上头条的' }
    print(dic1.get("wife").get("name")) print(dic1.get("children")) print(dic1.get("children")[1])
    练习: dic1 = {    'name':['alex',2,3,5],    'job':'teacher',    'oldboy':{'alex':['python1','python2',100]}    } 1,将name对应的列表追加一个元素’wusir’。 2,将name对应的列表中的alex首字母大写。 3,oldboy对应的字典加一个键值对’老男孩’,’linux’。 4,将oldboy对应的字典中的alex对应的列表中的python2删除

    作业:

    ,有如下变量(tu是个元祖),请实现要求的功能
    tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11, 22, 33)}, 44])
    a.讲述元祖的特性;;答:元祖用()表示,是只读列表,可以索引切片,循环,迭代,但是不能删改.
    b.请问tu变量中的第一个元素"alex"是否可被修改 答:不可以被修改
    c.请问tu变量中的"k2"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素"Seven"
    '''k2对应的值是列表型数据,可以改变.'''
    tu[1][2]["k2"]=["age","name","Seven"]
    print(tu)
    d.请问tu变量中的"k3"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素"Seven"
    '''k3对应的值是元祖,不可以修改'''
    2, 字典dic, dic = {'k1': "v1", "k2": "v2", "k3": [11, 22, 33]}

    a.请循环输出所有的key
    print(dic.keys())
    b.请循环输出所有的value
    print(dic.values())
    c.请循环输出所有的key和value
    for a in dic.keys():
    print(a)
    print(dic.get(a))
    d.请在字典中添加一个键值对,"k4": "v4",输出添加后的字典
    dic["k4"]="v4"
    print(dic)
    e.请在修改字典中"k1"对应的值为"alex",输出修改后的字典
    dic["k1"]="alex"
    print(dic)
    f.请在k3对应的值中追加一个元素44,输出修改后的字典
    dic["k3"]=[11, 22, 33,44]
    print(dic)
    g.请在k3对应的值的第1个位置插入个元素18,输出修改后的字典
    dic["k3"]=[11,18, 22, 33,]
    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"]="很多免费的,世界最大的", "质量一般","量很大"
    print(av_catalog)
    b, 将此["质量很高,真的很高", "全部收费,屌丝请绕过"]列表的"全部收费,屌丝请绕过"删除。
    av_catalog["欧美"]["x-art.com"]="质量很高,真的很高"
    print(av_catalog)
    c, 将此["质量很高,真的很高", "全部收费,屌丝请绕过"]列表的"全部收 费,屌丝请绕过"删除。
    av_catalog["欧美"]["x-art.com"]="质量很高,真的很高"
    print(av_catalog)
    d, 将此["质量怎样不清楚,个人已经不喜欢日韩范了", "verygood"]列表的"verygood"全部变成大写。
    av_catalog["日韩"]["tokyo-hot"][1]=av_catalog["日韩"]["tokyo-hot"][1].upper()
    print(av_catalog)
    e, 给'大陆'对应的字典添加一个键值对'1048': ['一天就封了']
    av_catalog["大陆"]["1048"]="一天就封了"
    print(av_catalog)
    f, 删除此"letmedothistoyou.com": ["多是自拍,高质量图片很多", "资源不多,更新慢"]键值对。
    del av_catalog["欧美"]["letmedothistoyou.com"]
    print(av_catalog)
    g, 给此["全部免费,真好,好人一生平安", "服务器在国外,慢"]列表的第一个元素,加上一句话:'可以爬下来'
    av_catalog["大陆"]["1024"][1]="服务器在国外,慢,可以爬下来"
    print(av_catalog)
    4、有字符串"k:1|k1:2|k2:3|k3:4"处理成字典{'k': 1, 'k1': 2....}
    s=a.split("|")
    dic={}
    for s1 in s:
    dic[s1.split(":")[0]]=int(s1.split(":")[1])
    print(dic)

    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]
    li1=[]
    li2=[]
    dic={'k1': "大于66的所有值列表," ,'k2': "小于66的所有值列表"}
    for a in li:
    if a >66:
    li1.append(a)
    else:
    li2.append(a)
    dic["k1"]=str(li1)
    dic["k2"]=str(li2)
    print(dic)
    6、输出商品列表,用户输入序号,显示用户选中的商品

    商品列表:
    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 = ["苍老师", "东京热", "武藤兰", "波多野结衣"]
    l1 = []
    comment = input('请输入评论>>>')
    for i in li:
    if
    i in comment:
    comment = comment.replace(i, '*' * len(i))
    l1.append(comment)
    print(l1)

  • 相关阅读:
    在Win8下无法打开 hlp 帮助文件的问题
    ftp 终端命令
    为 Macbook 增加锁屏热键技巧
    苹果系统直接读写 ntfs 磁盘
    div 绝对布局居中
    2015-1-11
    unable to load default svn client
    ubuntu eclipse 安装svn
    centos mysq table is read only
    centos ssh 乱码
  • 原文地址:https://www.cnblogs.com/cz007/p/9221198.html
Copyright © 2011-2022 走看看