AttributeError:“ str”对象在获取json对象密钥时没有属性“ keys”错误

时间:2019-03-08 04:36:27

标签: python json csv export-to-csv

我正在尝试将json对象转换为csv文件。当我传递obj并将其打印时,它可以完美工作。但是,当我从#Problem行继续时,出现AttributeError:'str'对象没有属性'keys'。 我传递完全相同的对象。如何解决此错误并使其正常运行?

import json
import csv
import os

def flattenjson( b, delim ):
    val = {}
    for i in b.keys():
        if isinstance( b[i], dict ):
            get = flattenjson( b[i], delim )
            for j in get.keys():
                val[ i + delim + j ] = get[j]
        else:
            val[i] = b[i]
    return val

jjj = {
    "pk": 22,
    "model": "auth.permission",
    "fields": {
      "codename": "add_message",
      "name": "Can add message",
      "content_type": 8
   }
 }

print(flattenjson(jjj , "__" ))
#Problem
input = map( lambda x: flattenjson( x, "__" ), jjj )

columns = [ x for row in input for x in row.keys() ]
columns = list( set( columns ) )

with open( 'sad.csv', 'wb' ) as out_file:
    csv_w = csv.writer( out_file )
    csv_w.writerow( columns )

    for i_r in input:
        csv_w.writerow( map( lambda x: i_r.get( x, "" ), columns ) )

1 个答案:

答案 0 :(得分:0)

在lambda函数中进行迭代时,您将给出唯一被视为字符串的键

因此,以下是可能适合您的解决方案。

编辑代码,而不是传递唯一键作为参数,而是传递新的字典。

input = map( lambda x: flattenjson({x: jjj[x]}, "__" ), jjj )