有时,我们需要对日期进行简单的运算,这就要使用到了日期运算和转换的函数。
例如:
data:image/s3,"s3://crabby-images/b2ae6/b2ae6d19249a36ff1f1745d4b26d072e6f0a6338" alt=""
其中使用pd.to_datetime可以统一将time.strftime("%Y/%m/%d")生成的日期转换成日期格式的数据。time.strftime("%Y/%m/%d")生成的日期为字符串格式。
一、计算两组时间之间的间隔
在图中有两列的日期,我们可以直接求出它们之间的间隔,在计算之前要先确定一下日期列的数据是否是日期格式:
data:image/s3,"s3://crabby-images/78635/7863580398319acc6b9b195c3be38711eea8a1c0" alt=""
确定了都是日期格式就可以进行日期的计算:
data:image/s3,"s3://crabby-images/a5a66/a5a6646c9d1957164be08f44d2262852c9886bf6" alt=""
data:image/s3,"s3://crabby-images/70a28/70a28dcf806f6b4fcf5be6a160ce5b8d1aba8f71" alt=""
由上图可知,计算后的日期天数却有着一个days单位,这个 因为这个是属于timedelta64[ns]的数据属性:
data:image/s3,"s3://crabby-images/d947f/d947f18eff7179d79902965b760a400b15f05efa" alt=""
因此我们可以将其转换成整数,以方便我们后续的使用:
data:image/s3,"s3://crabby-images/6e1df/6e1dfeee1beff5c62a9517e0dfaa8469bbfdd8f1" alt=""
使用pd.to_numeric可以将其它形式的数据转换成整数型的数据。
我们在看看现在数据的类型:
data:image/s3,"s3://crabby-images/60603/60603c69d3ee8af4dce1364a120556258d18327d" alt=""
当然了,也可以使用函数来进行转换:
data:image/s3,"s3://crabby-images/08de7/08de7880b9be095ad52a62e8d2e42ad7feb665f9" alt=""
使用匿名函数的时候对每个元素使用一次.days就能将数据转换成整数。
timedelta的数据类型相互直接不能转换成年、周、月等,只能转换为天数、秒数、微妙数。而且在返回秒数和微笑数时,如果是负数时容易出错(例如:-3秒会被处理为-1天86397秒):
data:image/s3,"s3://crabby-images/9b2f7/9b2f7e321ec8df47d413aba88a78c97a784f48dd" alt=""
在两个日期直接进行计算之后:
data:image/s3,"s3://crabby-images/b9e04/b9e04ef7c3752ad570d47799884936f1a939f441" alt=""
所以在日期计算之后为负数的时候就会出错,因此在转换间隔秒数的时候最后使用total_seconds()函数(记得函数后面的括号):
data:image/s3,"s3://crabby-images/1ecd5/1ecd5e78497dbe35f67b7478c6bc5f23e783da87" alt=""
网友评论