python如何批量输出语句_python如何合并批量输出

问 题

A文件夹 里面有

1.json

2.json

3.json

.....

格式为

{

"hello": "hello",

"data": [

{

"id": "123456",

"create_time": "2016-03-28 11:41:00",

"phone": "138888****",

"name": "aaa"

},

{

"id": "456789",

"create_time": "2016-03-28 11:41:00",

"phone": "137777****",

"name": "bbb"

}

]

}

遍历A文件夹

合并data内容

输出1个json和csv

解决方案

Python2:

import os

import csv

import glob

import json

data = []

for fname in glob.glob(os.path.join('A', '*.json')):

with open(fname) as f:

jf = json.loads(f.read())

data.extend(jf['data'])

with open('output.json', 'w') as f:

print >>f, json.dumps(data, sort_keys=True, indent=4, separators=(',', ': '))

with open('output.csv', 'w') as f:

writer = csv.writer(f)

writer.writerow([key for key, value in data[0].items()])

for d in data:

writer.writerow([value for key, value in d.items()])

Python3:

import os

import csv

import glob

import json

data = []

for fname in glob.glob(os.path.join('A', '*.json')):

with open(fname) as f:

jf = json.loads(f.read())

data.extend(jf['data'])

with open('output.json', 'w') as f:

print(json.dumps(data, sort_keys=True, indent=4, separators=(',', ': ')), file=f)

with open('output.csv', 'w') as f:

writer = csv.writer(f)

writer.writerow([key for key, value in data[0].items()])

for d in data:

writer.writerow([value for key, value in d.items()])

對於你說的合併,我這邊僅僅是將資料一筆一筆的疊加上去,並沒有作 id 檢查等處理。

csv 的輸出要求,可能也要視你想要的格式進行調整。

下面是相關的一些文檔,看完後對你會很有幫助:

扫一扫关注IT屋

微信公众号搜索 “ IT屋 ” ,选择关注与百万开发者在一起

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值