如何解决如何将 Pandas 数据框转换为 folium 中的 GeoJson 覆盖
[我这里有这个代码,但问题是当我做 folium.GeoJson(data,name="geojson") 它只返回 ValueError: 无法渲染缺少任何几何图形的对象:0 {'type': 'Multipolygon','坐标': [[[[-7 ....
import requests
import json
import pandas as pd
import folium
map = folium.Map(location=\[40,-73\],zoom_start=6,tiles="OpenStreetMap")
fg = folium.FeatureGroup(name="Parks",show = False)
map.add_child(fg)
park_data = requests.get("https://data.cityofnewyork.us/resource/enfh-gkve.json")
park_data = park_data.json()
park_frame = pd.DataFrame(data=park_data)
park_geo_data = park_frame["multipolygon"]
fg.add_child(folium.GeoJson(park_geo_data,name = "Parks"))
map.add_child(folium.LayerControl(position="topright"))
map.save("about.html")
``` See image for what the data looks like raw from the rest api][1]
[Shows error as well as shows what raw rest api response looks like][2]
[1]: https://i.stack.imgur.com/dGsql.png
[2]: https://i.stack.imgur.com/XlKdS.png
解决方法
您可以遍历数据框的行并将行的“multipolygon”列作为 geojson 特征添加到 featureGroup。
park_data = pd.read_json("https://data.cityofnewyork.us/resource/enfh-gkve.json")
for i,row in park_data.iterrows():
geo_data = row['multipolygon']
fg.add_child(folium.GeoJson(geo_data))
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。