字典dict是无序的key:value格式的数据序列

#coding:utf-8
#/usr/bin/python
"""
2018-11-11
dinghanhua
字典
""" '''dict 无序的key:value组合
key要是不可变类型,如数字、字符串、元组
key不可重复,重复的会被最后一个覆盖
'''
dict_id = {'':'python','':'java','':'javascript','':'go','':'JAVA'}
print(dict_id)
'''查询、新增、修改、删除数据,长度len()'''
print('dict包含的键值对个数:',len(dict_id)) print('取值dict[key]',dict_id[''])#查询
print('取值dict.get(key,default)',dict_id.get('','no key'),dict_id.get('','no key')) #存在key取value,不存在取默认值
print('是否存在key','' in dict_id) # key in dict
#print('key不存在,报keyerror错误:',dict_id['6']) dict_id[''] = 'java2' #更新数据
print(dict_id) dict_id[''] = 'php' #新增数据
print(dict_id) del dict_id[''] #删除数据
print(dict_id) dict_id[''] = 'test'
print(dict_id)
popele = dict_id.pop('')
print('popele=%s,dict is %s'%(popele,dict_id))
'''查看所有的key,value'''
for k in dict_id:
print(k,end=' ')
print(dict_id[k]) #只取keys
print(dict_id.keys())
#只取values
print(dict_id.values())
#取key,value
print(dict_id.items())
for k,v in dict_id.items():
print(k,v)
'''用序列list、tuple、set生成dict的key'''
li = ['dog','cat','dinosaur']
dict_li = {}
dict_li = dict_li.fromkeys(li)
print(dict_li) ss = {'dog','cat','pig'}
dict_li2 = dict_li.fromkeys(ss,'') #第二个参数是默认的value值
print(dict_li2) '''dict合并'''
dict_li.update(dict_li2) # dict2的添加到dict1中
print(dict_li)
'''排序 sorted'''
print('排序:',sorted(dict_id)) #默认按键排序
li = sorted(dict_id.values()) #values排序
print(li) li = sorted(dict_id.items()) #key,value默认按key排序
print(li) li = sorted(dict_id.items(),key=lambda item:item[1]) #按value排序
print(li)
'''练习:将cookie字符串改成dict'''
cookie = '_ga=GA1.2.1595072447.1537137596; _gid=GA1.2.1806558744.1541837860; ' \
'Hm_lvt_3eec0b7da6548cf07db3bc477ea905ee=1541250960,1541292056,1541837859,1541861084; ' \
'Hm_lpvt_3eec0b7da6548cf07db3bc477ea905ee=1541900415'
dict_cookie = {}
cookies = cookie.split(';')
for c in cookies:
cl = c.split('=')
dict_cookie[cl[0]] = cl[1]
print(dict_cookie)
'''练习:测试报告字符串格式化'''
template = """
<html>
<head>
<title>%(title)s</title>
</head>
<body>
<h1>%(head)s</h1>
<p>%(para1)s</p>
</body>
</html>
"""
dict_report = {'title':'testreport','head':'xx项目测试报告','para1':'该测试报告包含以下几部分。。。'}
print(template%dict_report)
'''练习:去除dict的value重复项,保留其中一个'''
cookie = {'_ga': 'GA1.2.1595072447.1537137596', ' _gid': 'GA1.2.1806558744.1541837860', ' Hm_lvt_3eec0b7da6548cf07db3bc477ea905ee': '1541250960,1541292056,1541837859,1541861084', ' _gid2': 'GA1.2.1806558744.1541837860', ' Hm_lpvt_3eec0b7da6548cf07db3bc477ea905ee': ''} # 定义一个新的字典,如果value不在新的dict.values里,则插入
dict_new = {}
for key,value in cookie.items():
if value not in dict_new.values():
dict_new[key] = value
print('替换后:',dict_new) #利用dict的key自动去重
dict_new2 = {}
for key,value in cookie.items():
dict_new2[value] = key
print('key和value对调之后已去重',dict_new2)
for key,value in dict_new2.items():
dict_new2[value] = key
dict_new2.pop(key)
print('再恢复key value对应关系',dict_new2) # 取所有的values值,个数大于1,则删除
dict_new = cookie.copy()
for key,value in cookie.items():
if list(dict_new.values()).count(value) >1:
del dict_new[key]
print(dict_new)
'''dict记录了成绩,计算平均分,最高分等'''
#只记录了一科成绩,算平均分,最高分的人
dic_data = {'aaa':70,'bbb':95,'ccc':95,'ddd':85} li_score = dic_data.values()
print('平均分:',sum(li_score)/len(li_score)) #平均分 maxscore = max(dic_data.values()) #最高分
for key,value in dic_data.items():
if value == maxscore:
print('No1 is %s'%key) #按分数排序,取第一个人名和最高分,不适合第一名有多个的
print(sorted(dic_data.items(),key = lambda x:x[1],reverse=True)[0]) #记录了3个科目的成绩,计算每个人的平均分,找到均分不及格的人;每个科目的平均分和最高分,每科的第一名
dic_data = {'aaa':[60,60,50],'bbb':[90,60,80],'ccc':[90,95,98],'ddd':[88,85,97]}
#计算每个人的平均分,value的平均分
for key,value in dic_data.items():
avg = sum(value)/len(value)
print('%s 的平均分是 %.2f'%(key,avg))
if avg < 60:
print('均分不及格') #计算各科的平均分和最高分 取value[i]的均分和最高
avglist = []
maxlist = []
lendic = len(dic_data)
for i in range(0,3):
li_score = [ value[i] for value in dic_data.values()] #取出每个科目的所有人的成绩列表
avglist.append(sum(li_score)/lendic) #平均分
maxlist.append(max(li_score)) #最高分
print('各科目平均分:',avglist)
print('各科目最高分:',maxlist)
print(list(zip(['语文','数学','英语'],avglist,maxlist))) #找最高分的学生
for key,value in dic_data.items():
for i in range(0,3):
if value[i] == maxlist[i]:
print('第%s个科目的最高分学生%s'%(i+1,key)) #排序
for i in range(0,3):
print(sorted(dic_data.items(),key = lambda x:x[1][i],reverse=True)) #各科目成绩倒序排
'''计算每个人的平均分; 科目的均分和最高分,及拿到最高分的人'''
dic_data = {'aaa':{'语文': 60, '数学': 60, '英语': 50},
'bbb':{'语文': 90, '数学': 60, '英语': 80},
'ccc':{'语文': 90, '数学': 95, '英语': 98},
'ddd':{'语文': 88, '数学': 85, '英语': 97}} #每个人的平均分
for key,value in dic_data.items():
avgscore = sum(value.values())/len(value.values()) #平均分
print('%s的平均分是%.2f'%(key,avgscore))
if avgscore < 60:
print('均分不及格') #科目最高分,均分
dict_course = {'语文':None,'数学':None,'英语':None}
for key in dict_course:
li_score = [ value[key] for value in dic_data.values()]
print(key,li_score)
print('%s平均分:%.2f'%(key,sum(li_score)/len(li_score)))
print('%s最大值:%.2f'%(key,max(li_score)))
#得分最高的
for name,score in dic_data.items():
if score[key] == max(li_score):
print('科目%s得分最高的是%s'%(key,name))

the end!

python入门14 字典dict的更多相关文章

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

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

  2. python中的字典(dict),列表(list),元组(tuple)

    一,List:列表 python内置的一种数据类型是列表:list.list是一种有序的数据集合,可以随意的添加和删除其中的数据.比如列出班里所有的同学的名字,列出所有工厂员工的工号等都是可以用到列表 ...

  3. Python入门之字典的操作详解

    这篇文章主要介绍了Python 字典(Dictionary)的详细操作方法,需要的朋友可以参考下: Python字典是另一种可变容器模型,且可存储任意类型对象,如字符串.数字.元组等其他容器模型. 一 ...

  4. python基础类型(字典:dict)

    字典的介绍: 字典(dict)Python中唯一的一个映射类型.他是以{}括起来的键值对组成,在dict中key是唯一的.在保存的时候,根据key来计算出一个内存地址,然后将key-value保存到这 ...

  5. python 浅谈字典dict

    一.字典简介 字典(dict)是python中唯一的映射类型,他是以{ }括起来的键值对组成,在dict中的key是唯一的.在保存的时候,根据key来计算出一个内存地址.然后将key-value保存在 ...

  6. Python内置字典;dict ,set

    dict and set dict:  键-值 /重复添加 set :  键 / key不能重复 对于不变对象来说,调用对象自身的任意方法,也不会改变该对象自身的内容.相反,这些方法会创建新的对象并返 ...

  7. python——Container之字典(dict)详解

    字典(dictionary)是除列表以外python之中最灵活的内置数据结构类型.列表是有序的对象结合,字典是无序的对象集合.两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取. ...

  8. Python 列表list 字典dict

    # coding=utf-8 支持中文 # 列表 n1 = [1, 2, 3] print n1 print len(n1) n1.append(4) print n1 # 字典,包含键值 dic = ...

  9. python入门之字典

    1.字典的基本特征: key-value结构 key唯一,必须为不可变数据类型 value可以不唯一 无序 查找速度快 2.创建一个字典: info={“gaohui”:"IT", ...

随机推荐

  1. 《UML和模式应用(原书第3版)》目录

    学习 <UML和模式应用(原书第3版)>目标: 理解OOA/D思想 如何使用UML建模 如何使用设计模式 如何设计分层架构 目录: 第1部分 绪论 第1章 面向对象分析和设计 第2章 迭代 ...

  2. encoding specified in XML prolog (UTF-8) is different from that specified in page directive (utf-8)

    myeclipse下启动项目后出现错误:encoding specified in XML prolog (UTF-8) is different from that specified in pag ...

  3. (转)linux下进程的进程最大数、最大线程数、进程打开的文件数和ulimit命令修改硬件资源限制

    ulimit命令查看和更改系统限制 ulimit命令详解 ulimit用于shell启动进程所占用的资源,可以用来设置系统的限制 语法格式 ulimit [-acdfHlmnpsStvw] [size ...

  4. poi 多行合并

    poi做多行合并,一定需要先绘制单元格,然后写入数据,最后合并,不然各种坑啊. 合并单元格所使用的方法: sheet.addMergedRegion( CellRangeAddress  cellRa ...

  5. mongodb insert()、save()的区别

    mongodb 的 insert().save()  ,区别主要是:若存在主键,insert()  不做操作,而save() 则更改原来的内容为新内容. 存在数据:  { _id : 1, " ...

  6. 无监督学习(Unsupervised Learning)

    无监督学习(Unsupervised Learning) 聚类无监督学习 特点 只给出了样本, 但是没有提供标签 通过无监督学习算法给出的样本分成几个族(cluster), 分出来的类别不是我们自己规 ...

  7. jqGrid 将行的字变成超连接

    今天在项目中碰到要将jqGrid中的行做成超连接,请看代码步骤: name: , align: "left", formatter: function (cellValue, op ...

  8. AtCoder Grand Contest 023 F - 01 on Tree

    Description 题面 Solution HNOI-day2-t2 复制上去,删点东西,即可 \(AC\) #include<bits/stdc++.h> using namespa ...

  9. SpringSecurity 3.2入门(6)简单介绍默认使用的十一个过滤器

    Security提供了20多个filter,每个过滤器都提供特定的功能.这些filter在Spring Security filter过滤器链中的缺省顺序由 org.springframework.s ...

  10. artDialog组件应用学习(二)

    一.没有操作选项的对话框 预览: html前台引入代码:(之后各种效果对话框引入代码致,调用方法也一样,就不一一写入) <script type="text/javascript&qu ...