- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
json_str = '[
{
"name": "t1",
"props": [
{
"abc": 10012,
"def": "OBJECT"
},
{
"abc": 999123,
"def": "SUBJECT"
}
],
"id": 1,
"title": "king"
},
{
"name": "t2",
"props": [
{
"abc": 789456,
"def": "PRODUCT"
}
],
"id": 2,
"title": "queen"
}
]'
使用上面的 JSON,我想创建一个扩展
props
列表并连接到主要 json 列的数据框。
id,title,name,abc,def
与行:
1,king,t1,10012,OBJECT
1,king,t1,999123,SUBJECT
2,queen,t2,789456,PRODUCT
当我尝试这个时:
jdata = json.loads(json_str)
pd.concat([pd.DataFrame(jdata), pd.DataFrame(list(jdata['props']))], axis=1).drop('props', 1)
我收到此错误:
list indices must be integers or slices, not str
jdata=json.loads(json_str)
pd.concat([pd.DataFrame(jdata), pd.DataFrame([pd.json_normalize(jdata, "props", errors="ignore", record_prefix="")])], axis=1).drop('props', 1)
抛出这个错误:
Must pass 2-d input. shape={values.shape}
result = pd.json_normalize(jdata, 'props', errors="ignore", record_prefix="props.")
result2 = pd.json_normalize(jdata, errors="ignore", record_prefix="tmpl.")
df = pd.concat([result, result2], axis=1).drop('props', 1)
这里没有抛出错误,但是
concat
没有将两个 df 对齐。行不同步。
最佳答案
您可以使用 json_normalize 来简化提取;对于每个 record_path
都会有一个关联的 meta
:
json_normalize(data = jdata,
record_path = 'props',
meta = ['name', 'id', 'title']
)
abc def name id title
0 10012 OBJECT t1 1 king
1 999123 SUBJECT t1 1 king
2 789456 PRODUCT t2 2 queen
关于python - 在 Pandas 中将外部 json 与嵌套的 json 结合起来并创建新的数据框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67188012/
我正在尝试执行 vagrant up 但一直遇到此错误: ==> default: IOError: [Errno 13] Permission denied: '/usr/local/lib/pyt
我在容器 div 中有一系列动态创建的不同高度的 div。 Varying text... Varying text... Varying text... Varying text.
通过 cygwin 运行 vagrant up 时遇到以下错误。 stderr: /bin/bash: /home/vagrant/.ansible/tmp/ansible-tmp-14872260
今天要向小伙伴们介绍的是一个能够快速地把数据制作成可视化、交互页面的 Python 框架:Streamlit,分分钟让你的数据动起来! 犹记得我在做机器学习和数据分析方面的毕设时,
我是 vagrant 的新手,正在尝试将第二个磁盘添加到我正在用 vagrant 制作的虚拟机中。 我想出了如何在第一次启动虚拟机时连接磁盘,但是当我关闭机器时 然后再次备份(使用 'vagrant
我是一名优秀的程序员,十分优秀!