一、字典操作

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

语法:

1、基本语法

 >>> info = {
'stu1101': "Ma Qing",
'stu1102': "Pei Lin",
'stu1103': "Wang Chuan",
'stu1104': "Cai Jin",
}
>>> print(info)
{'stu1104': 'Cai Jin', 'stu1103': 'Wang Chuan', 'stu1102': 'Pei Lin', 'stu1101': 'Ma Qing'}

2、字典的特性:

  • dict是无序的

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

3、字典增加

 >>> info["stu1105"] = "蔡文华"
>>> print(info)
{'stu1104': 'Cai Jin', 'stu1105': '蔡文华', 'stu1103': 'Wang Chuan', 'stu1102': 'Pei Lin', 'stu1101': 'Ma Qing'}

4、修改

 >>> info["stu1101"] = "马青"
>>> print(info)
{'stu1104': 'Cai Jin', 'stu1105': '蔡文华', 'stu1103': 'Wang Chuan', 'stu1102': 'Pei Lin', 'stu1101': '马青'}

5、删除

 #方法一:
>>> info.pop("stu1101")
'马青'
>>> print(info)
{'stu1104': 'Cai Jin', 'stu1105': '蔡文华', 'stu1103': 'Wang Chuan', 'stu1102': 'Pei Lin'}
#方法二:
>>> del info["stu1105"]
>>> print(info)
{'stu1104': 'Cai Jin', 'stu1103': 'Wang Chuan', 'stu1102': 'Pei Lin'}
#随机删除
>>> info.popitem()
('stu1104', 'Cai Jin')
>>> print(info)
{'stu1103': 'Wang Chuan', 'stu1102': 'Pei Lin'}

6、查找

>>> info = {
'stu1101': "Ma Qing",
'stu1102': "Pei Lin",
'stu1103': "Wang Chuan",
'stu1104': "Cai Jin",
}
#如果差绕的key在字典中不存在,则程序报错
>>> info["stu1102"]
'Pei Lin'
#推荐用get判断,无论字典中是否有要查找的key,python不会报错
>>> info.get("stu1103")
'Wang Chuan'
>>> info.get("stu1105")

判断字典中是否存在某个值

 print("stu1103" in info)    #如果不存在报错!

7、多级字典嵌套

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

8、其他用法

1)values 将字典中的所有values值,生成一个列表

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

2)keys将字典中的所有keys值,生成一个列表

 >>> av_catalog.keys()
dict_keys(['欧美', '日韩', '大陆'])

3)setdefault(k,v)

setdefault()表示去取字典中的key,如果取不到,则设置新值,相反如果取到,则返回原有默认值。

4)update更新字典。如果原字典已有数据已新字典内容为准

  info = {
'stu1101': "Ma Qing",
'stu1102': "Pei Lin",
'stu1103': "Wang Chuan",
'stu1104': "Cai Jin",
}
>>> info2 = {1:2,3:4,"stu1103":"王川"} >>> info.update(info2)
>>> info
{'stu1103': '王川', 1: 2, 'stu1101': 'Ma Qing', 'stu1104': 'Cai Jin', 3: 4, 'stu1102': 'Pei Lin'}

5)items 将字典转化为列表

 >>> info.items()
dict_items([('stu1103', '王川'), (1, 2), ('stu1101', 'Ma Qing'), ('stu1104', 'Cai Jin'), (3, 4), ('stu1102', 'Pei Lin')])

6)#通过一个列表生成默认dict,有个没办法解释的坑,少用吧这个

 >>> info3 = dict.fromkeys([6,7,8],"test")
>>> print(info3)
{8: 'test', 6: 'test', 7: 'test'}
  c = dict.fromkeys([6,7,8],[1,{"name":"maqing"},666])
>>> print(c)
{8: [1, {'name': 'maqing'}, 666], 6: [1, {'name': 'maqing'}, 666], 7: [1, {'name': 'maqing'}, 666]}
>>> c[7][1]["name"] = "Peilin"
>>> print(c)
{8: [1, {'name': 'Peilin'}, 666], 6: [1, {'name': 'Peilin'}, 666], 7: [1, {'name': 'Peilin'}, 666]}

7)dict的循环

 #输出字典
for i in info :
print(i,info[i])
#方法二,先把字典转化为列表,然后输出列表
for k,v in info.items():
print(k,v)

Day2-Python基础2---字典操作的更多相关文章

  1. Python基础之字典操作

    字典 字典的优点: dict key 必须是不可变数据类型,可哈希, value:任意数据类型. dict 优点:二分查找去查询 存储大量的关系型数据 特点:无序的(指的是不可人为的去改变顺序) 数据 ...

  2. Day2 - Python基础2 列表、字典、集合

    Python之路,Day2 - Python基础2   本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一, ...

  3. python基础之字典dict和集合set

    作者:tongqingliu 转载请注明出处:http://www.cnblogs.com/liutongqing/p/7043642.html python基础之字典dict和集合set 字典dic ...

  4. Python基础数据类型-字典(dict)

    Python基础数据类型-字典(dict) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的每一篇都是Python3.x版本的哟 ...

  5. python基础篇(文件操作)

    Python基础篇(文件操作) 一.初始文件操作 使用python来读写文件是非常简单的操作. 我们使用open()函数来打开一个文件, 获取到文件句柄. 然后通过文件句柄就可以进行各种各样的操作了. ...

  6. Day2 - Python基础2 列表、字符串、字典、集合、文件、字符编码

    本节内容 列表.元组操作 数字操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 ...

  7. python基础之字典、集合

    一.字典(dictionary) 作用:存多个值,key-value存取,取值速度快 定义:key必须是不可变类型,value可以是任意类型 字典是一个无序的,可以修改的,元素呈键值对的形式,以逗号分 ...

  8. Python day2 ---python基础2

    本节内容 列表. 元组操作 购物车程序 字符串操作 字典操作 3级菜单 作业(购物车优化) 1. 列表操作 1.定义列表names = ['Alex',"Tenglan",'Eri ...

  9. Python之路,Day2 - Python基础(转载Alex)

    Day2-转自金角大王 本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存 ...

  10. python 基础之字典一

    字典特点:无序.键唯一 字典的创建 bag = {'cx':'chenxi','gghg':35} print(bag['cx']) 测试 chenxi Process finished with e ...

随机推荐

  1. Android编译系统简要介绍【转】

    本文转载自:http://blog.csdn.net/luoshengyang/article/details/18466779 在Android源码环境中,我们开发好一个模块后,再写一个Androi ...

  2. Android LCD(三):LCD接口篇【转】

    本文转载自:http://blog.csdn.net/xubin341719/article/details/9177085 关键词:Android LCD控制器 Framebuffer PWM  平 ...

  3. Eclipse常用插件安装_PropertiesEditor

    properties文件在项目中多用做i18n国际化支持的配置文件,在properties文件中出现的中文信息都要转换为Unicode文本,一般的做法都是使用JDK自带的native2ascii工具进 ...

  4. 深入Struts2的过滤器FilterDispatcher--中文乱码及字符编码过滤器

    引用 前几天在论坛上看到一篇帖子,是关于Struts2.0中文乱码的,楼主采用的是spring的字符编码过滤器(CharacterEncodingFilter)统一编码为GBK,前台提交表单数据到Ac ...

  5. 算法总结之 将单链表的每K个节点之间逆序

    给定一个单链表的表头节点head,实现一个调整单链表的函数,是的每k个节点之间逆序,如果最后不够k个节点一组,则不调整最后几个节点 思路: 如果k的值小于2,不调整.k<1 没有意义,k==1代 ...

  6. js获取css样式方法

    一.CSS样式共有三种:内联样式(行间样式).内部样式.外部样式(链接式和导入式) <div id="a" style="width: 100px;height: ...

  7. BZOJ 4066 kd-tree 矩形询问求和

    第一次遇见强制在线的题目 每个操作都和前面的ans有关 所以不能直接离线做 在这个问题中 kdtree更像一个线段树在一维单点修改区间询问的拓展一样 如果区间被询问区间完全包含 就不用继续递归 插入时 ...

  8. SoapUI使用方法-01发送http请求

    soap ui http://blog.csdn.net/russ44/article/details/51680083 一.发送HTTP请求消息 1.打开soapUI. 2.新建一个项目,实例如下: ...

  9. 总结django知识点

    一.视图函数:     请求对象-----------request:           1.HttpRequest.body:         请求原数据           2.HttpRequ ...

  10. tensorflow实现Minist手写体识别

    import tensorflow as tf from tensorflow.examples.tutorials.mnist import input_data #下载MINIST数据集mnist ...