<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
在Pandas中我們在處理時間序列的時候常用的方法有:
pd.to_datetime()
pd.date_range()
# pd.date_range() index = pd.date_range("20210101",periods=20) index Out[29]: DatetimeIndex(['2021-01-01', '2021-01-02', '2021-01-03', '2021-01-04', '2021-01-05', '2021-01-06', '2021-01-07', '2021-01-08', '2021-01-09', '2021-01-10', '2021-01-11', '2021-01-12', '2021-01-13', '2021-01-14', '2021-01-15', '2021-01-16', '2021-01-17', '2021-01-18', '2021-01-19', '2021-01-20'], dtype='datetime64[ns]', freq='D') # pd.to_datetime() df = pd.DataFrame(data=range(20210101,20210128),columns=["period"]) df["aa"] = pd.to_datetime(df["period"],format="%Y%m%d") df Out[24]: period aa 0 20210101 2021-01-01 1 20210102 2021-01-02 2 20210103 2021-01-03 3 20210104 2021-01-04 4 20210105 2021-01-05 5 20210106 2021-01-06 6 20210107 2021-01-07 7 20210108 2021-01-08 8 20210109 2021-01-09 9 20210110 2021-01-10 10 20210111 2021-01-11 11 20210112 2021-01-12 12 20210113 2021-01-13 13 20210114 2021-01-14 14 20210115 2021-01-15 15 20210116 2021-01-16 16 20210117 2021-01-17 17 20210118 2021-01-18 18 20210119 2021-01-19 19 20210120 2021-01-20 20 20210121 2021-01-21 21 20210122 2021-01-22 22 20210123 2021-01-23 23 20210124 2021-01-24 24 20210125 2021-01-25 25 20210126 2021-01-26 26 20210127 2021-01-27 index[1] Out[30]: Timestamp('2021-01-02 00:00:00', freq='D') df["aa"][1] Out[31]: Timestamp('2021-01-02 00:00:00') df["aa"][1] == index[1] Out[32]: True type(df["aa"][1]) Out[33]: pandas._libs.tslibs.timestamps.Timestamp type(index[1]) Out[34]: pandas._libs.tslibs.timestamps.Timestamp
從上面程式碼可以看出,pandas中的時間格式是pandas._libs.tslibs.timestamps.Timestamp
但是python中常用的時間格式是datetime.datetime
to_pydatetime()
t = datetime(2021,1,2) type(t) Out[54]: datetime.datetime t Out[55]: datetime.datetime(2021, 1, 2, 0, 0) r = (index[1].to_pydatetime()) type(r) Out[57]: datetime.datetime t == r Out[58]: True
將pandas Timestamp 轉為 datetime 型別
In [11]: ts = pd.Timestamp('2014-01-23 00:00:00', tz=None) In [12]: ts.to_pydatetime() Out[12]: datetime.datetime(2014, 1, 23, 0, 0)
It's also available on a DatetimeIndex rng = pd.date_range('1/10/2011', periods=3, freq='D') rng.to_pydatetime() Out[60]: array([datetime.datetime(2011, 1, 10, 0, 0), datetime.datetime(2011, 1, 11, 0, 0), datetime.datetime(2011, 1, 12, 0, 0)], dtype=object)
官方檔案: https://pandas.pydata.org/pandas-docs/stable/user_guide/timeseries.html
最近需要提取某一天的時刻距離0:00的分鐘數,找了檔案之後想到這樣一個辦法:
In [64]: stamps = pd.date_range('2012-10-08 18:15:05', periods=4, freq='h') In [65]: stamps Out[65]: DatetimeIndex(['2012-10-08 18:15:05', '2012-10-08 19:15:05', '2012-10-08 20:15:05', '2012-10-08 21:15:05'], dtype='datetime64[ns]', freq='D')
先得到距離1970-01-01的秒數
In [66]: (stamps - pd.Timestamp("1970-01-01")) // pd.Timedelta('1s') Out[66]: Int64Index([1349720105, 1349723705, 1349727305, 1349730905], dtype='int64')
對天取餘,得到距離0:00的秒數
In [67]: (stamps - pd.Timestamp("1970-01-01")) // pd.Timedelta('1s') % 86400 Out[67]: Int64Index([65705, 69305, 72905, 76505], dtype='int64')
取距離0:00的分鐘數
In [68]: (stamps - pd.Timestamp("1970-01-01")) // pd.Timedelta('1s') % 86400 /60 Out[68]: Int64Index([1095.0833333333333, 1155.0833333333333, 1215.0833333333333, 1275.0833333333333], dtype='float64')
同樣的,也可以取小時數
In [69]: (stamps - pd.Timestamp("1970-01-01")) // pd.Timedelta('1s') % 86400 /3600 Out[68]: Int64Index([18.25138888888889, 19.25138888888889, 20.25138888888889, 21.25138888888889], dtype='float64')
取小時整數–當然取小時整數也有別的方法。
In [70]: (stamps - pd.Timestamp("1970-01-01")) // pd.Timedelta('1s') % 86400 //3600 Out[70]: Int64Index([18, 19, 20, 21], dtype='int64')
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45