Python 批量处理JSON文件,替换某个值

Python 批量处理JSON文件,替换某个值

直接上代码,替换key TranCode的值 New 为 Update。输出 cancel忽略

import json
import os
import io

path = 'D:\\Asics\\850\\202307'  # old
path2 = 'D:\\test2'  # new
dirs = os.listdir(path)
num_flag = 0
for file in dirs:  #
    if os.path.splitext(file)[1] == ".JSON":  #
        num_flag = num_flag + 1

        with io.open(os.path.join(path, file), 'r', encoding='utf-8') as load_f:
            load_dict = json.load(load_f)
        n = len(load_dict['Orders'])
        Orders = load_dict['Orders']
        OrderLines = Orders[0]['OrderLines']
        SKUs = OrderLines[0]['SKUs']
        flag=False
        for i in SKUs:
            if i['TranCode'] == 'New':  # error
                i['TranCode'] = 'Update'  # true
            if i['TranCode'] != 'Cancel':
                flag=True
        if(flag):
            with io.open(os.path.join(path2, file), 'w', encoding='utf-8') as dump_f:
                dump_f.write(unicode(json.dumps(load_dict,dump_f, ensure_ascii=False)))

if (num_flag == 0):
    print('Sorry no files')
else:
    print('release{} number json files'.format(num_flag))

数据结构
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值