如何将数据插入到文件内的JSON数组中?

2024-09-23 00:19:16 发布

您现在位置:Python中文网/ 问答频道 /正文

问题:

我正在做一个文件元项目,它从一个文件夹中收集文件信息并将其存储在一个JSON文件中。你知道吗

我的空JSON文件如下所示

数据库.json

{
    "samples" : []
}

现在我的想法是扫描每个文件,然后像这样将每个记录插入samples数组

数据库.json

{
    "samples" : [
{
    "file_name": "ba18524fe5d5c6e99b99c7da66dbbfa094ab8f61",
    "file_new_location": "/home/admin/",
    "file_path": "/home/admin/vt_files/ba18524fe5d5c6e99b99c7da66dbbfa094ab8f61",
    "file_source": "VT",
    "md5": "149c4ac4ba0863607e033d6a5721fee7",
    "mime": "application_x-dosexec",
    "severity": "high",
    "sha256": "50bc946af55f0a5deb66f935229046c1ec74fb2233d71efa3ae064a073a771f5"
}
]
}

但我的问题是,每当我试图插入记录,我不能插入到样本,但在一行来。你知道吗

for file_original_name in files:
    file_meta = {}
    file_meta['file_name'] = file_original_name
    file_meta['file_path'] = os.path.join(root,file_original_name)
    file_meta['file_source'] = source
    file_meta['severity'] = severity
    file_meta['md5'] = md5(file_meta['file_path'])
    file_meta['sha256'] = sha256(file_meta['file_path'])
    mime = magic.Magic(mime=True)
    file_meta['mime'] = mime.from_file(file_meta['file_path']).replace('/','_')
    file_meta['file_new_location'] = '{}/{}/{}/{}'.format(default_root,severity,file_meta['mime'],file_original_name)
    try:
        extracted_new_dir = os.path.join(default_root,severity,file_meta['mime'])
        if not os.path.isdir(extracted_new_dir):
            os.makedirs(extracted_new_dir)
        if delete:
            move(file_meta['file_path'],file_meta['file_new_location'])
        else:
            copyfile(file_meta['file_path'],file_meta['file_new_location'])
        print json.dumps(file_meta,sort_keys=True,indent=4)
    except Exception as e:
        print e
    result[file_original_name] = (file_meta)
    with open('db.json','a') as f:
        json.dump(result , f)

对如何解决这个问题有什么建议吗?你知道吗


Tags: 文件pathnamejsonsourcenewoslocation