我有一些包含嵌套字典的数据,如下所示:
mylist = [{"a": 1, "b": {"c": 2, "d":3}}, {"a": 3, "b": {"c": 4, "d":3}}]
如果我们将其转换为pandas DataFrame,
import pandas as pd
result_dataframe = pd.DataFrame(mylist)
print(result_dataframe)
它将输出:
a b
0 1 {'c': 2, 'd': 3}
1 3 {'c': 4, 'd': 3}
我希望将字典列表转换,并忽略嵌套字典的键。我的代码如下:
new_dataframe = result_dataframe.drop(columns=["b"])
b_dict_list = [document["b"] for document in mylist]
b_df = pd.DataFrame(b_dict_list)
frames = [new_dataframe, b_df]
total_frame = pd.concat(frames, axis=1)
我的需求是 total_frame:
a c d
0 1 2 3
1 3 4 3
但是我认为我的代码有些复杂。有没有简单的方法来解决这个问题?谢谢。
df_data = [{"a": el["a"], **el["b"]} for el in mylist]
- Tom Wojcik