我正在尝试将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 ) )
答案 0 :(得分:0)
在lambda函数中进行迭代时,您将给出唯一被视为字符串的键
因此,以下是可能适合您的解决方案。
编辑代码,而不是传递唯一键作为参数,而是传递新的字典。
input = map( lambda x: flattenjson({x: jjj[x]}, "__" ), jjj )