我正在讀一個CSV到一個變量「東西」,並強迫第一列到POSIXct(此列只有時間戳,形式爲「2012-12-04 17:49:52」,所以這個效果很好)。POSIXct平等工作奇怪
stuff[,1]<-as.POSIXct(stuff[,1])
因爲我有好幾天的價值的數據,我則試圖通過日期,打破東西:
control <- subset(stuff,as.Date(stuff[,1]) == '2012-11-27')
control.1 <- subset(stuff,as.Date(stuff[,1]) == '2012-11-28')
我覺得這不會將數據增長日期爲分割我會期待的。 尾(控制)告訴我,最後一個值是在2012-11-27 15:54:21,而頭(control.1)顯示它的第一個值是2012-11-27 16:04:35。
因爲某些原因,平等因此似乎在16:00左右的某個地方發生。我試圖在強制使用POSIXct時指定時區,但這也沒有幫助。有什麼我可以做的白天子集(這是否有失敗的原因)?我想提一提,我需要將小時信息保存在那裏,因爲我打算隨後使用它來分割數據。
這是因爲時區。您可以在as.Date中指定時區,默認情況下它是UTC,因此當您將時間戳轉換爲日期時,一些將落在不同的日期。確保你的時區在as.Date匹配你的時間戳時區 – ilya
我試圖修復時間戳,說'stuff [,1] < - as.Date(stuff [,1],tzone =「PST」)',並指定時間區域也在平等檢查中,但我得到了相同的結果。 有趣的是,我得到了正確的結果,如果我這樣做: 'control < - subset(cases,cases [,1] <= as.POSIXct('2012-11-27 23:59:59'))' – padips