我使用OmegaHat的RGoogleDocs包将我的Google表格电子表格导入到R. 其中一些包含日期数据,时间数据和日期/时间数据。Google表格导入到R的日期和时间对象
在导入到R后,RGoogleDocs会将日期和时间转换为十进制数字,推测可能是从开始引用1900-1-1(或1899-12-30)开始的秒数。
这对日期来说不是问题,因为我只需使用as.Date()
即可将其转换。 但是,时间数据是一个巨大的麻烦。
我知道我可以使用as.POSIXct()
或as.POSIXlt()
但是,这并不能准确地将十进制数转换回日期和时间。
Observe:
Timestamp:
2/10/2014 19:22:40; 2/10/2014 19:52:07; 2/10/2014 20:14:47;
2/10/2014 21:08:03; 2/11/2014 11:05:39; 2/11/2014 12:21:40;
2/11/2014 12:44:33; 2/11/2014 16:08:54; 2/11/2014 16:31:44;
2/12/2014 10:54:31; 2/12/2014 11:38:15; 2/12/2014 11:56:18;
2/12/2014 12:31:53; 2/12/2014 14:42:46; 2/12/2014 15:03:36;
2/13/2014 14:38:17; 2/13/2014 15:08:45; 2/13/2014 16:39:27;
2/13/2014 17:18:45; 2/13/2014 19:14:23; 2/19/2014 15:01:16;
2/19/2014 15:05:43;
RGoogleDocs'进口版本:
> mydata$"Timestamp"
[1] 41680.81 41680.83 41680.84 41680.88 41681.46 41681.52 41681.53 41681.67
[9] 41681.69 41682.45 41682.48 41682.50 41682.52 41682.61 41682.63 41683.61
[17] 41683.63 41683.69 41683.72 41683.80 41689.63 41689.63
转换后:
as.POSIXct(mydata$"Timestamp"*86400, origin = "1899-12-30")
[1] "2014-02-11 00:22:40 PKT" "2014-02-11 00:52:07 PKT" "2014-02-11 01:14:47 PKT"
[4] "2014-02-11 02:08:02 PKT" "2014-02-11 16:05:39 PKT" "2014-02-11 17:21:40 PKT"
[7] "2014-02-11 17:44:33 PKT" "2014-02-11 21:08:54 PKT" "2014-02-11 21:31:44 PKT"
[10] "2014-02-12 15:54:31 PKT" "2014-02-12 16:38:15 PKT" "2014-02-12 16:56:18 PKT"
[13] "2014-02-12 17:31:53 PKT" "2014-02-12 19:42:45 PKT" "2014-02-12 20:03:36 PKT"
[16] "2014-02-13 19:38:17 PKT" "2014-02-13 20:08:45 PKT" "2014-02-13 21:39:27 PKT"
[19] "2014-02-13 22:18:45 PKT" "2014-02-14 00:14:22 PKT" "2014-02-19 20:01:16 PKT"
[22] "2014-02-19 20:05:42 PKT"
不仅是时间不准确,误差逐渐增加,在列表中向下。谁能帮忙?
你能提供一个链接到你的谷歌电子表格的公共版本(甚至只是时间戳列)吗? – hrbrmstr
https://docs.google.com/spreadsheet/ccc?key = 0AqIRsZWcpw-gdEJZV01UVGNSWkxqSlI1VkRrN2NOdXc&usp = sharing – naveedpash