欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

PythonDay3---字典的基本操作

程序员文章站 2024-03-23 17:29:34
...

字典的基本操作:

字典一种key - value 的数据类型,使用就像我们上学用的字典,通过笔划、字母来查对应页的详细内容。

语法:

info = {
    "dic1":"wuhan"
    "dic2":"beijing"
    "dic1":"shenzhen"
}

字典的特性:

  • dict是无序的
  • key必须是唯一的,so 天生去重

增加、修改:

info["dic4"] = "guangzhou"  # 增加
print(info)
info["dic2"] = "dongbei"   #修改
print(info)
运行结果:
{'dic1': 'wuhan', 'dic2': 'beijing', 'dic3': 'shenzhen', 'dic4': 'guangzhou'}
{'dic1': 'wuhan', 'dic2': 'dongbei', 'dic3': 'shenzhen', 'dic4': 'guangzhou'}

删除:

info.pop("dic2")  # 标准删除方式
print(info)
运行结果:{'dic1': 'wuhan', 'dic3': 'shenzhen'}
del info("dic1") # del删除
print(info)
运行结果:{'dic2': 'beijing', 'dic3': 'shenzhen'}
info.popitem() #随机删除
print(info)
运行结果:{'dic1': 'wuhan', 'dic2': 'beijing'}  # 这里可能觉得是删除最后一个,其实只是列表的数据太少,看不出效果

查找:

print("dic2" in info) # 判断"dic2"是否在字典中,如果不在就返回Flase,在就返回True
运行结果:True
print(info.get("dic3")) # 获取"dic3"的数值,如果查询的key不在字典中就会报错
运行结果:shenzhen
print(info["dic3"]) # 效果和上面使用get一样
运行结果:shenzhen

循环:

# 方法一
for key in info:
    print(key,info[key])
# 方法二
for k,v in info.items():
    print(k,v)
运行结果:
dic1 wuhan
dic2 beijing
dic3 shenzhen

多级字典的嵌套:

 这个就比较简单,这里直接给出一个别人使用的例子,但这些网站就建议不要去试了,hahah...

av_catalog = {
    "欧美":{
        "www.youporn.com": ["很多免费的,世界最大的","质量一般"],
        "www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
        "letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
        "x-art.com":["质量很高,真的很高","全部收费,屌比请绕过"]
    },
    "日韩":{
        "tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","听说是收费的"]
    },
    "大陆":{
        "1024":["全部免费,真好,好人一生平安","服务器在国外,慢"]
    }
}

av_catalog["大陆"]["1024"][1] += ",可以用爬虫爬下来"
print(av_catalog["大陆"]["1024"])
#ouput 
['全部免费,真好,好人一生平安', '服务器在国外,慢,可以用爬虫爬下来']

其他的一些用法:

#values
>>> info.values()
dict_values(['LongZe Luola', 'XiaoZe Maliya'])

#keys
>>> info.keys()
dict_keys(['stu1102', 'stu1103'])

#setdefault
>>> info.setdefault("stu1106","Alex")
'Alex'
>>> info
{'stu1102': 'LongZe Luola', 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'}
>>> info.setdefault("stu1102","龙泽萝拉")
'LongZe Luola'
>>> info
{'stu1102': 'LongZe Luola', 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'}

#update 
>>> info
{'stu1102': 'LongZe Luola', 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'}
>>> b = {1:2,3:4, "stu1102":"龙泽萝拉"}
>>> info.update(b)
>>> info
{'stu1102': '龙泽萝拉', 1: 2, 3: 4, 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'}

#items
info.items()
dict_items([('stu1102', '龙泽萝拉'), (1, 2), (3, 4), ('stu1103', 'XiaoZe Maliya'), ('stu1106', 'Alex')])

#通过一个列表生成默认dict,有个没办法解释的坑,少用吧这个
>>> dict.fromkeys([1,2,3],'testd')
{1: 'testd', 2: 'testd', 3: 'testd'}