我想标准化以下JSON:
[
{
"studentId": 1,
"studentName": "James",
"schools": [
{
"schoolId": 1,
"classRooms": [
{
"classRoomId": {
"id": 1,
"floor": 2
}
},
{
"classRoomId": {
"id": 3
}
},
],
"teachers": [
{
"teacherId": 1,
"teacherName": "Tom"
},
{
"teacherId": 2,
"teacherName": "Sarah"
}
]
},
{
"schoolId": 2,
"classRooms": [
{
"classRoomId": {
"id": 4
}
}
],
"teachers": [
{
"teacherId": 1,
"teacherName": "Tom"
},
{
"teacherId": 2,
"teacherName": "Sarah"
},
{
"teacherId": 3,
"teacherName": "Tara"
}
]
}
]
}
]
我想用Python(表格形式)获取下表:
studentId studentName schoolId classRoomId.id classRoomId.floor teacherId
teacherName
1 James 1 1 2 1 Tom
1 James 1 1 2 2 Sarah
1 James 1 3 1 Tom
1 James 1 3 2 Sarah
1 James 2 4 1 Tom
1 James 2 4 2 Sarah
1 James 2 4 3 Tara
我试图像这样使用Pandas的json_normalize函数:
df1 = json_normalize(test1, ["schools","teachers"], ["studentId", "studentName",["schools","teachers"]])
df2 = json_normalize(test1, ["schools","classRooms"], ["studentId", "studentName",["schools","classRooms"]])
df = pd.concat([df1,df2],axis=1)
但这并没有给我我所需的结构。
它不一定必须在Pandas中,Python中的任何其他库或代码都可以。任何帮助都感激不尽。谢谢。
答案 0 :(得分:1)
由于classRooms
和teachers
形成了JSON的两个不同的子树,因此您必须将它们解析两次:
classrooms = pd.io.json.json_normalize(json_data, ['schools', 'classRooms'], meta=[
'studentId',
'studentName',
['schools', 'schoolId']
])
teachers = pd.io.json.json_normalize(json_data, ['schools', 'teachers'], meta=[
'studentId',
['schools', 'schoolId']
])
# Merge and rearrange the columns in the order of your sample output
classrooms.merge(teachers, on=['schools.schoolId', 'studentId']) \
[['studentId', 'studentName', 'schools.schoolId', 'classRoomId.id', 'classRoomId.floor', 'teacherId', 'teacherName']]