一份数据文件根据“历史风暴_编号”分为多个group组,每个组是一组风暴经纬度轨迹。想每个组分别绘制一条经纬度折线。
不知道该如何操作。如果组比较少,可以 分别 ax1.plot操作。但是有上百个组,也就是有上百个轨迹线,有什么操作方法,python不太熟,谢谢!
下面这段代码直接把所有轨迹首尾相连了,怎么让每组分别一条折线呢?
filename=r'E:\Science\Software Program\PythonProjects\DataProcessing\Hail_Path_2022\风暴信息预处理_限定范围_经纬度_汇总 - 剔除后 -统一编号.xls'
df=pd.read_excel(filename,sheet_name='Sheet1')
df_group=df.groupby('历史风暴_编号')
for x in df_group.size().index:
dff=df_group.get_group(x)
经度=df['历史风暴_经度(°)']
纬度=df['历史风暴_纬度(°)']
ax1.plot(经度,纬度,'k.-',linewidth=0.8,markersize=2,label='')
如何才能达到下面的效果呢?
循环体内plt.plot的数据没有变化,应该是每次都绘制了全部数据,重复了3次。你需要将数据分组,每次绘制一条轨迹线。另外,当轨迹线很多的时候,matplotlib效率会比较低,建议使用matplotlib.collections的LineCollection,官网有详细的资料。