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使用的更多相关文章

  1. json.dump()和json.dmups()的区别

    在python中支持json合适的数据是通过json模块实现的. 在序列化json数据的时候遇到两个形状很像的函数,dump()和dumps().主要说说他们的区别 先看看官方文档的说明:https: ...

  2. json.dumps(),json.loads(),json.dump(),json.load()方法的区别

    1. json.dumps() json.dump()是将字典类型转化成字符串类型. import json dic = {'a':'1111','b':'2222','c':'3333','d':' ...

  3. python json.dumps() json.dump()的区别

    以前写的很简单,只有几句话,最近发现本文是本博客阅读量最大的一篇文章,觉得这样有种把人骗进来的感觉,于是又细化了一些.如果还有不好的地方,欢迎指出. 首先说明基本功能: dumps是将dict转化成s ...

  4. python中json文件处理涉及的四个函数json.dumps()和json.loads()、json.dump()和json.load()的区分

    一.概念理解 1.json.dumps()和json.loads()是json格式处理函数(可以这么理解,json是字符串) (1)json.dumps()函数是将一个Python数据类型列表进行js ...

  5. json.dumps与json.dump的区别 json.loads与json.load的区别

    json.dumps是将一个Python数据类型列表进行json格式的编码解析, 示例如下: >>> import json #导入python 中的json模块>>&g ...

  6. json.dump和json.dumps区别,json.load和json.loads的区别

    dumps是将python类型(list,dict等)转化成str格式,loads是将str转化成python类型(list,dict等). dump和load也是类似的功能,只是与文件操作结合起来了 ...

  7. python中json.load()、json.loads()、json.dump()、json.dumps()的区别

    json.load()从文件中读取json字符串 json.loads()将json字符串转换为字典类型 json.dumps()将python中的字典类型转换为字符串类型 json.dump()将j ...

  8. 【Python基础】json.dumps()和json.loads()、json.dump()和json.load()的区分

    json文件处理涉及的四个函数json.dumps()和json.loads().json.dump()和json.load()的区分 一.概念理解 1.json.dumps()和json.loads ...

  9. json -- dump load dumps loads 简单对比

    json.dumps是将一个Python数据类型列表进行json格式的编码解析, 示例如下: >>> import json #导入python 中的json模块>>&g ...

随机推荐

  1. sencha touch 在新版谷歌浏览器中painted事件无法触发解决方案以及carousel 控件、togglefield控件、滚动条失效

    在2.3/2.4版本中,新版谷歌浏览器(43.44版本)里面painted事件是不会触发的,以及carousel 控件.togglefield控件.滚动条失效,官方的解决方案如下,测试可用 会出现这个 ...

  2. rx.js 的冷和热观察

    http://cn.rx.js.org/manual/overview.html#h213 https://rxjs-cn.github.io/rxjs5-ultimate-cn/content/ho ...

  3. maven 配置mirror后,本地库与远端库冲突

    settings.xml中主要包括以下元素: localRepository interavtiveMode offline pluginGroups proxies servers mirrors ...

  4. 转:关于ROWNUM的使用

    转载自:原文:https://blog.csdn.net/songsenkeji/article/details/4432942 ROWNUM的概念ROWNUM是一个虚假的列.它将被分配为 1,2,3 ...

  5. java.util.ResourceBundle学习笔记

    一.初次使用,从网上查的资料,知识点参考JDK API和博文http://lavasoft.blog.51cto.com/62575/184605(该博主写的清晰易懂) 二.自己在程序中的具体应用: ...

  6. PHP一个小函数

    // function makeTemp($fileName="index",$ftype=0) { $tempPath="xx/xxxx/{$fileName}.htm ...

  7. 用U盘制作并安装WIN10 64位原版系统的详细教程(该方法应该适用于任何一版的原版操作系统)

    https://www.cnblogs.com/Jerseyblog/p/6518273.html

  8. Luogu 1603 - 斯诺登的密码 - [简单字符串操作]

    题目链接:https://www.luogu.org/problemnew/show/P1603 题目背景 根据斯诺登事件出的一道水题 题目描述 2013年X月X日,俄罗斯办理了斯诺登的护照,于是他混 ...

  9. 深度学习模型stacking模型融合python代码,看了你就会使

    话不多说,直接上代码 def stacking_first(train, train_y, test): savepath = './stack_op{}_dt{}_tfidf{}/'.format( ...

  10. SQL Server 2008 事件探查器(SQL SERVER Profiler)

    要想很好地优化ERP系统,可以从客户端.服务器.网络等入手,对于我们M1系统的优化来说,SQL 语句的优化就起到很重要的作用了.为此,我们展开,学习了SQL SERVER 2008的事件探查器(SQL ...