我有一个xarray数据集,包含以下信息:
Coordinates:
lat: float64 (192)
lon: float64 (288)
time: object (1200) (monthly data)
Data Variables:
tas: (time, lat, lon)
字符串
现在我想要特定月份的tas值,例如我想要包含1月份所有记录的新数据集。
输出数据集将如下所示:
Coordinates:
lat: float64 (192)
lon: float64 (288)
time: object (100) (monthly data of January)
Data Variables:
tas: (time, lat, lon)
型
我尝试了一种我以前用过的方法:
jan = pd.date_range(start='1979-01-01', periods=41, freq='AS-JAN').date.tolist()
gs_jan = gs.sel(time = jan)
型
但这不会在我的情况下工作,因为我的日期是在0001-0100年,Pandas不支持在这个范围内的日期!
3条答案
按热度按时间7gcisfzg1#
一般来说,要分析这样的时间序列数据,您需要使用xarray的
da.groupby()
方法(http://xarray.pydata.org/en/stable/groupby.html)遵循group-split-apply方法。在你的情况下,我建议尝试:
字符串
希望这对你有帮助!
gopyfrb32#
另一种用更少的代码完成此任务的方法是使用
xarray.where()
字符串
a8jjtwal3#
虽然the answer by Andrew已经解决了这个问题,但是如果您只希望提取一个特定的月份,
字符串
这里,1表示January。它更像是一个字典,所以只需使用键(实际上是
groupby
对象中的标签)就可以检索到特定的月份,而不需要首先检索索引。