PythonDay3---字典的基本操作

字典的基本操作:

字典一种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'}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值