用Python画出漂亮的地图
地图可视化是数据分析和地理信息系统中的重要环节。Python提供了多个强大的库,如Folium
、Matplotlib
、Geopandas
等,使得创建漂亮而具有信息量的地图变得简单而灵活。本文将详细介绍如何使用这些库绘制漂亮的地图,并提供丰富的示例代码
pip install folium matplotlib geopandas
import folium
# 创建地图对象
m = folium.Map(location=[37.7749, -122.4194], zoom_start=12)
# 在地图上添加标记
folium.Marker([37.7749, -122.4194], popup='San Francisco').add_to(m)
# 保存地图为HTML文件
m.save('interactive_map.html')
import matplotlib.pyplot as plt
import geopandas as gpd
# 读取世界地图数据
world = gpd.read_file(gpd.datasets.get_path('naturalearth_lowres'))
# 绘制世界地图
world.plot()
plt.title('World Map')
plt.show()
import geopandas as gpd
import matplotlib.pyplot as plt
# 读取世界地图数据
world = gpd.read_file(gpd.datasets.get_path('naturalearth_lowres'))
# 可视化地图
world.plot(column='gdp_md_est', cmap='OrRd', legend=True, figsize=(15, 10))
plt.title('World Map with GDP')
plt.show()
import folium
from folium.plugins import HeatMap
# 创建地图对象
m = folium.Map(location=[37.7749, -122.4194], zoom_start=12)
# 添加热力图数据点
heat_data = [[37.7749, -122.4194] for _ in range(100)]
# 添加热力图层
HeatMap(heat_data).add_to(m)
# 保存地图为HTML文件
m.save('heatmap.html')
import geopandas as gpd
import matplotlib.pyplot as plt
# 读取城市数据
cities = gpd.read_file(gpd.datasets.get_path('naturalearth_cities'))
# 绘制世界地图
world = gpd.read_file(gpd.datasets.get_path('naturalearth_lowres'))
ax = world.plot(figsize=(15, 10))
# 在地图上添加城市标记
cities.plot(ax=ax, marker='o', color='red', markersize=50)
plt.title('World Map with City Markers')
plt.show()
import plotly.express as px
# 读取世界地图数据
world = px.data.world()
# 绘制世界地图
fig = px.choropleth(world, locations='iso_alpha', color='pop',
hover_name='country', color_continuous_scale='Viridis',
title='World Map with Population')
fig.show()
import folium
# 创建地图对象
m = folium.Map(location=[37.7749, -122.4194], zoom_start=12, control_scale=True)
# 添加自定义标记
folium.Marker([37.7749, -122.4194], popup='San Francisco', icon=folium.Icon(color='red')).add_to(m)
# 添加自定义边界
folium.RegularPolygonMarker([37.7808, -122.4128], popup='Another Location',
fill_color='#132b5e', number_of_sides=4, radius=10).add_to(m)
# 添加文本标签
folium.Marker([37.7749, -122.4194], popup='<strong>San Francisco</strong>', tooltip='Click me!').add_to(m)
# 保存地图为HTML文件
m.save('customized_map.html')
import folium
# 创建地图对象
m = folium.Map(location=[37.7749, -122.4194], zoom_start=12)
# 添加路径
folium.PolyLine(locations=[[37.7749, -122.4194], [37.7808, -122.4128]],
color='blue', weight=2.5, opacity=1).add_to(m)
# 保存地图为HTML文件
m.save('path_map.html')
import folium
from folium.plugins import TimestampedGeoJson
# 创建地图对象
m = folium.Map(location=[37.7749, -122.4194], zoom_start=12)
# 添加时间戳地理JSON数据
geojson_data = {
'type': 'FeatureCollection',
'features': [
{
'type': 'Feature',
'geometry': {'type': 'Point', 'coordinates': [-122.4194, 37.7749]},
'properties': {'time': '2023-01-01T00:00:00'}
},
{
'type': 'Feature',
'geometry': {'type': 'Point', 'coordinates': [-122.4128, 37.7808]},
'properties': {'time': '2023-01-02T00:00:00'}
}
]
}
TimestampedGeoJson(geojson_data, period='PT1H', duration='PT1H').add_to(m)
# 保存地图为HTML文件
m.save('animated_map.html')
注意:
以上代码皆为示例代码,并非具体实现