题目是这样的:

给定一个字典dict1,将其转换成dict2:
dict1 = {
'fetal':[{u'key': u'sjzx_sy22_121.201.56.5', u'doc_count': 23}, {u'key': u'sjzx_sy21_121.201.56.4', u'doc_count': 4}],
'warning':[{u'key': u'sjzx_sy22_121.201.56.5', u'doc_count': 30}, {u'key': u'sjzx_sy21_121.201.56.4', u'doc_count': 50}]
} dict2 = {'sjzx_sy22_121.201.56.5': [{'fetal': 23}, {'warning': 30}], 'sjzx_sy21_121.201.56.4': [{'fetal': 4}, {'warning': 50}]}

脑子摩擦了一个下午:

dict1 = {
'fetal': [{u'key': u'sjzx_sy22_121.201.56.5', u'doc_count': 23},
{u'key': u'sjzx_sy21_121.201.56.4', u'doc_count': 4}],
'warning': [{u'key': u'sjzx_sy22_121.201.56.5', u'doc_count': 30},
{u'key': u'sjzx_sy21_121.201.56.4', u'doc_count': 50}]
} def getvalue(dictcome, key):
retdict = {}
for item in dictcome.get(key): # 遍历传入字典的key为传入key值的对应value,item为{'key': 'sjzx_sy22_121.201.56.5', 'doc_count': 23}
valuelist = list(item.values()) # 将item的value值保存为列表
# ['sjzx_sy22_121.201.56.5', 23]//['sjzx_sy21_121.201.56.4', 4]
retdict[valuelist[0]] = {key: valuelist[1]} # 保存为dict2字典的格式,主要是提取dict2的key
return retdict # {'sjzx_sy22_121.201.56.5': {'fetal': 23}, 'sjzx_sy21_121.201.56.4': {'fetal': 4}} def combindtwo(dicta, dictb): # 合并两个字典,key值唯一,相同key对应的value保存为列表格式
for i,j in dictb.items():
if i in dicta.keys():
listtmp = [dicta.get(i), j]
dicta.update({f'{i}': listtmp})
else:
dicta.update({f'{i}': dictb[i]})
return dicta tmplist = [] for key in dict1.keys():
tmplist.append(getvalue(dict1, key)) # 这里按dict1的key值调用getvalue参数,将dict1换一种格式输入
# 将获取到的字典保存在列表里,但是下面调用combindtwo函数时,我是直接用item取的。。。我觉得怪怪的。但不知道该如何做?? print('原字典为:')
print(dict1)
print('修改后的字典如下:')
print(combindtwo(tmplist[0], tmplist[1]))

最后输入结果为:(也算是达到目的了吧= =)

原字典为:
{'fetal': [{'key': 'sjzx_sy22_121.201.56.5', 'doc_count': 23}, {'key': 'sjzx_sy21_121.201.56.4', 'doc_count': 4}], 'warning': [{'key': 'sjzx_sy22_121.201.56.5', 'doc_count': 30}, {'key': 'sjzx_sy21_121.201.56.4', 'doc_count': 50}]}
修改后的字典如下:
{'sjzx_sy22_121.201.56.5': [{'fetal': 23}, {'warning': 30}], 'sjzx_sy21_121.201.56.4': [{'fetal': 4}, {'warning': 50}]}

然后看一下给我出题的大佬写的程序:

def get_ip_count(d):
result = {}
for key, values in d.items():
for ip_result in values:
# 以 IP 为键,设置值为默认空列表
result.setdefault(ip_result['key'], [])
# result[ip_result['key']] = []
result_count = {}
result_count[key] = ip_result['doc_count']
result[ip_result['key']].append(result_count)
return result if __name__ == '__main__':
d = {'fetal': [{u'key': u'sjzx_sy22_121.201.56.5', u'doc_count': 23},
{u'key': u'sjzx_sy21_121.201.56.4', u'doc_count': 4}],
'warning': [{u'key': u'sjzx_sy22_121.201.56.5', u'doc_count': 30},
{u'key': u'sjzx_sy21_121.201.56.4', u'doc_count': 50}]
} result = get_ip_count(d)
print(result)

大佬说:难点在于先构造空字典,构造出空字典之后,在下一个循环又不会被冲掉。

setdefault()方法:

dict.setdefault(key[,default=None])
  • key -- 字典中要查找的键。
  • default -- 可选参数,如果指定键的值不存在时,返回该值,默认为 None。
  • 返回指定键的值,如果指定键的值不在字典中返回指定值,默认为 None。

呵呵。

我要继续努力!

python-关于字典与列表的一个作业的更多相关文章

  1. python:字典嵌套列表

    Python的字典{ }以键值对的形式保存数据,可以以键来访问字典中保存的值而不能用下标访问.字典中几乎可以包含任意的变量,字典,数列,元组.数列也一样. python的列表[ ]与字典不同,列表通过 ...

  2. 零基础入门学习Python(11)--列表:一个打了激素的数组(2)

    前言 上节课我们介绍一个打了激素的数组,叫做列表.列表我们比作一个大仓库,你所能够具现化的东西,都可以往里面扔,它包罗万象.另外还介绍了三个往列表添加元素的方法,分别是: append(),exten ...

  3. 零基础入门学习Python(10)--列表:一个打了激素的数组

    前言 有时候我们需要把一些东西暂时保存起来,因为他们有着一些直接或间接的联系,我们需要把它们放在某个组或者集合中,未来可能用得上. 很多接触过编程的朋友都知道,都接触过数组这个概念,那么数组这个概念事 ...

  4. Python把两个列表合成一个字典

    简单粗暴上代码 A= [] B = [] C= dict(map(lambda x,y:[x,y],A,B)) 酱紫,就合成了一个字典

  5. python之字典、列表、元组生成器的使用

    python的生成式在一些类型相互转换的时候可以写出十分优雅的代码.如列表转换成另一个列表.字典.或元组.并且代码的执行效率也比使用for...in...循环高. 列表生成式 列表生成式即生成列表的生 ...

  6. 零基础入门学习Python(12)--列表:一个打了激素的数组(3)

    前言 这节课我们继续谈一下Python列表一些知识 知识点 Python常用操作符 比较操作符 >>> list1 = [123] >>> list2 = [234 ...

  7. python对字典及列表递归排序

    对字典内所有内容进行排升序排序,包括,子数组,子字典 需要注意: 1.字典因为是在一定程序上无序的,所以这里采用了内置包,来变成有序字典 from collections import Ordered ...

  8. Python的字典、列表合并

    字典合并: 在日常工作中需要对字典进行合并操作,下面提供几个操作方法 1.使用dict(a,**b) 例: >>> a={'a':1,'b':2} >>> b={' ...

  9. python 字典和列表嵌套用法

    python中字典和列表的使用,在数据处理中应该是最常用的,这两个熟练后基本可以应付大部分场景了.不过网上的基础教程只告诉你列表.字典是什么,如何使用,很少做组合说明. 刚好工作中采集promethe ...

随机推荐

  1. IE7下使用兼容Icon-Font CSS类

    Iconfont在IE7下需要使用unicode方式,但是这种方式不太方便,使用以下代码可使IE7像普通用法使用. @font-face {font-family: "anticon&quo ...

  2. express session 和 socketio session关联

    express session http是没有状态的协议, 需要web框架自己实现会话和会话管理工作. express框架有session插件可以使用. 见如下介绍: https://www.tuto ...

  3. order by 的用法

    select * from emp order by sal desc  --将员工工资按照由高到低的顺序排列

  4. neo4j语法

    图数据库在社交网络.实时推荐.征信系统.人工智能等领域有广泛应用. 集群特征:主从复制,重选主服务器和容错:每个实例都有自己的本地缓冲 性能优势:查询内不跨网络:实时操作,具有快速和一致的响应时间:缓 ...

  5. Linux命令--tree

    目录 tree 最常用 带颜色显示2级目录 排除显示某个目录 tree tree -C :颜色显示 tree -f : 显示文件全路径 tree -L 2 :只显示2层 tree -P *.pl :只 ...

  6. important覆盖行内样式

    优先级,外部样式<内部样式<行内样式,后台富文本编辑器编辑的正文显示在前台时可用!important覆盖其行内样式 今天的问题,font-family:"思源黑体 CN!impo ...

  7. Linux initramfs说明

    1.前言 最近在尝试对手头的开发板进行移植,此处记录initramfs挂载的基本流程,记录一下,以备后查.分析时是基于linux3.4.2 2. rootfs的挂载 start_kernel-> ...

  8. Python简单爬虫获取岗位招聘人数

    #encoding=utf-8 import selenium import selenium.webdriver import re import time # pip install seleni ...

  9. leveldb(ssdb)性能、使用场景评估

    最近有个业务场景存储压力很大,写远远大于读,读也集中在最近写入,想想这不很适合采用leveldb存储么.leveldb的话好像用ssdb比较多,花了两天时间就ssdb简单做下测试,以下总结. ssdb ...

  10. Win10 中将网页转换成pdf的简便方法

    注意:该方法不是将网页完整地保存下来,而是选取其中主要的文字信息. (1)打开要保存的网页 (2)按快捷键 Ctrl+P 打开打印界面 (3)选择打印机为 “Microsoft Print to PD ...