[py]初始化dict结构和json.dump使用
1.json.dump使用
http://python3-cookbook.readthedocs.io/zh_CN/latest/c06/p02_read-write_json_data.html
- 针对文件
json.dump
json.load
ps:各台机器机器本地计算, os.walk根据目录算出目录下所有文件绝对路径,遍历后汇总成一个数组做处理
2.字典数据结构:使用前先初始化
- d有一级 d = {'name':[]}
d = {}
if d.get('name'):
d['name'].append('maotai')
else:
d['name'] = []
- d有两级: d = {'name':{k:[]}}
d = {}
for i in data:
if d.get(i[0]):
if d[i[0]].get(i[1]):
d[i[0]][i[1]].append(i[2])
else:
d[i[0]][i[1]] = [i[2]]
else:
d[i[0]] = {i[1]: [i[2]]}
较完善的一个例子
import os
import json
# 获取数据
def get_data():
data = []
with open('/tmp/res/res.txt') as f:
for i in f:
ip = i.split()[0]
hash_val = i.split()[1]
file_name = os.path.basename(i.split()[2])
data.append([file_name, hash_val, ip])
# print(json.dumps(data))
# 处理数据
d = {}
for i in data:
if d.get(i[0]):
if d[i[0]].get(i[1]):
d[i[0]][i[1]].append(i[2])
else:
d[i[0]][i[1]] = [i[2]]
else:
d[i[0]] = {i[1]: [i[2]]}
# print(json.dumps(d))
# 生成html
html_tmpl_start = '''
<table border='1' cellspacing="0">
<tr>
<td>file_name</td>
<td>hash</td>
<td>ip</td>
</tr>
'''
html_tmpl_file_begin = '<tr>'
html_tmpl_file = '''
<td rowspan="%s">%s</td>
'''
html_tmpl_hash = '''
<td>%s</td>
'''
html_tmpl_ip = '''
<td>%s</td>
'''
html_tmpl_ip_end = '</tr>'
html_tmpl_end = '</table>'
html_content = ''
# 统计下同一个file有几个hash
# print(d)
for k, v in d.items():
html_tmpl_file_res = ''
html_tmpl_hash_res = ''
html_tmpl_ip_res = ''
flag = 1
if len(v) > 1:
# file: k, 看hash
html_tmpl_file_res = html_tmpl_file % (len(list(v.keys())), k)
# print(html_tmpl_file_res)
# hash: k is hash,v is ip,看ip
for m, n in v.items():
if flag == 1:
html_tmpl_hash_res = html_tmpl_hash % (m)
html_tmpl_ip_res = html_tmpl_ip % (n)
tmp = html_tmpl_file_begin + html_tmpl_file_res + html_tmpl_hash_res + html_tmpl_ip_res + html_tmpl_ip_end
flag += 1
else:
html_tmpl_hash_res = html_tmpl_hash % (m)
html_tmpl_ip_res = html_tmpl_ip % (n)
tmp = html_tmpl_file_begin + html_tmpl_hash_res + html_tmpl_ip_res + html_tmpl_ip_end
html_content += tmp
content = html_tmpl_start + html_content + html_tmpl_end
return content
[py]初始化dict结构和json.dump使用的更多相关文章
- json.dump()和json.dmups()的区别
在python中支持json合适的数据是通过json模块实现的. 在序列化json数据的时候遇到两个形状很像的函数,dump()和dumps().主要说说他们的区别 先看看官方文档的说明:https: ...
- json.dumps(),json.loads(),json.dump(),json.load()方法的区别
1. json.dumps() json.dump()是将字典类型转化成字符串类型. import json dic = {'a':'1111','b':'2222','c':'3333','d':' ...
- python json.dumps() json.dump()的区别
以前写的很简单,只有几句话,最近发现本文是本博客阅读量最大的一篇文章,觉得这样有种把人骗进来的感觉,于是又细化了一些.如果还有不好的地方,欢迎指出. 首先说明基本功能: dumps是将dict转化成s ...
- python中json文件处理涉及的四个函数json.dumps()和json.loads()、json.dump()和json.load()的区分
一.概念理解 1.json.dumps()和json.loads()是json格式处理函数(可以这么理解,json是字符串) (1)json.dumps()函数是将一个Python数据类型列表进行js ...
- json.dumps与json.dump的区别 json.loads与json.load的区别
json.dumps是将一个Python数据类型列表进行json格式的编码解析, 示例如下: >>> import json #导入python 中的json模块>>&g ...
- json.dump和json.dumps区别,json.load和json.loads的区别
dumps是将python类型(list,dict等)转化成str格式,loads是将str转化成python类型(list,dict等). dump和load也是类似的功能,只是与文件操作结合起来了 ...
- python中json.load()、json.loads()、json.dump()、json.dumps()的区别
json.load()从文件中读取json字符串 json.loads()将json字符串转换为字典类型 json.dumps()将python中的字典类型转换为字符串类型 json.dump()将j ...
- 【Python基础】json.dumps()和json.loads()、json.dump()和json.load()的区分
json文件处理涉及的四个函数json.dumps()和json.loads().json.dump()和json.load()的区分 一.概念理解 1.json.dumps()和json.loads ...
- json -- dump load dumps loads 简单对比
json.dumps是将一个Python数据类型列表进行json格式的编码解析, 示例如下: >>> import json #导入python 中的json模块>>&g ...
随机推荐
- Qt编写通用主界面V2019
其实是2018年做出来的这个界面效果,用该界面做了三四个项目,今天抽空特意提取出来单独的demo,集成到了皮肤生成器中.
- 一、K3 Wise 实施指导《K3 Wise实施手册》
1.总账期间启用后无法修改.固定资产期间启用后无法修改 ----修改总账 ' where fcategory='GL' and Fkey='startyear' --修改启用期间 ' where fc ...
- springboot JPA
JPA(Java Persistence API)是Sun官方提出的Java持久化规范.它为Java开发人员提供了一种对象/关联映射工具来管理Java应用中的关系数据.他的出现主要是为了简化现有的持久 ...
- [Android实例] app引导页(背景图片切换加各个页面动画效果)(申明:来源于网络)
[Android实例] app引导页(背景图片切换加各个页面动画效果)(申明:来源于网络) 地址: http://www.eoeandroid.com/thread-918356-1-1.html h ...
- hdu6363 bookshelf 容斥+数列+数论gcd定理(也可以Möbius)
#define _CRT_SECURE_NO_WARNINGS #include<cmath> #include<iostream> #include<stdio.h&g ...
- shell脚本之分析oracle数据库数据泵日志中表的大小
1.分析日志格式如下 . . imported "xxx_330508"."xxx_T_DATA" 46.17 MB 268 rows . . imported ...
- 单KEY业务,数据库水平切分架构实践 | 架构师之路
https://mp.weixin.qq.com/s/8aI9jS0SXJl5NdcM3TPYuQ 单KEY业务,数据库水平切分架构实践 | 架构师之路 原创: 58沈剑 架构师之路 2017-06- ...
- 2017年蓝桥杯省赛A组c++第1题(走迷宫)
/* 标题:迷宫 X星球的一处迷宫游乐场建在某个小山坡上. 它是由10x10相互连通的小房间组成的. 房间的地板上写着一个很大的字母. 我们假设玩家是面朝上坡的方向站立,则: L表示走到左边的房间, ...
- [daily][qemu][kvm] qemu增加减少CPUID
做 DPDK 大页内存测试, 发现KVM模拟出来的CPU不支持 1GB 的大页 可以使用如下命令是否支持: [root@dpdk ~]# cat /proc/cpuinfo |grep pdpe1gb ...
- 转:JAVA中解决Filter过滤掉css,js,图片文件等问题
原文链接:https://www.cnblogs.com/ermeng/p/6440966.html public void doFilter(ServletRequest request, Serv ...