python遍历JSON对象并写入csv

时间:2019-03-11 10:13:36

标签: python json for-loop

我正在尝试遍历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子句在a: flat_attr(getattr(issue, a))之后,而for和if在该行之前时,循环如何工作?如何打印“ a”来调试代码?

谢谢!

1 个答案:

答案 0 :(得分:0)

如果要调试在特定行中传递的数据,则可以使用Pycharm之类的IDE。使用Pycharm,您可以保留断点,并且可以在运行时对应用程序进行 debug 的选择,现在您可以轻松地 debug 您的程序了。

只需尝试。.