首页 > 解决方案 > python遍历JSON对象并写入csv

问题描述

我正在尝试遍历 JSON 对象,并写入新的 CSV 文件。

无论如何,我在尝试此代码时遇到错误:

def flat_attr(thisAttr):   
        if type(thisAttr) is bytes:
            thisAttr = (thisAttr.decode('utf-8'))[:1500] 
        else: 
            try:
                thisAttr = str(thisAttr)[:1500]
            except: 
                thsAttr = thisAttr
        return thisAttr



    thisDate = (datetime.today().date())  
    thisFile = 'sim_' +  thisDate.strftime('%Y%m%d') + '.csv' 

    with open('/tmp/' + thisFile, 'w') as csvfile:
        writer = csv.DictWriter(csvfile, fieldnames = ['sim_id', 'data'], delimiter = '\t', lineterminator = '\n')
        counter = 0
        for issue in results.issues:
            counter += 1
            print('Writer written line ' + str(counter) + ' issue_id: ' + issue.main_id)
            print('Writer written line ' + str(counter) + ' issue_id: ' + issue.labels)
            writer.writerow({
                'sim_id': issue.main_id,
                'data': json.dumps({
                    for a in dir(issue):
                        if a in attr_list:
                            a: flat_attr(getattr(issue, a))
                            print(a)
                })
            })

错误是这个:

E       for a in dir(issue):
E         ^
E   SyntaxError: invalid syntax

当我将该 writerow() for 循环更改为以下代码时,它可以工作:

writer.writerow({
                'sim_id': issue.main_id,
                'data': json.dumps({
                    a: flat_attr(getattr(issue, a)) for a in dir(issue) if a in attr_list
                })
})

我想出道,这就是我尝试打印'a'的原因。

当 for 循环和 if 子句在 the 之后, a: flat_attr(getattr(issue, a))而当 for 和 if 在该行之前时,循环是如何工作的?如何打印“a”来调试代码?

谢谢!

标签: pythonjsonfor-loop

解决方案


好的,做一件事ZeleIB,将'a'的值附加到列表并返回列表以进行测试。
例子,

for a in dir(issue):
    debug_a = []
    if a in attr_list:
        a: flat_attr(getattr(issue, a))
        debug_a.append(a)

return {'test': debug_a}

推荐阅读