R错误中的格式化时间
formatting time in R error
我的 df
中有一个 Time
列,其值为 1.01.2016 0:00:05
。我想要它没有秒数,因此使用了 df$Time <- as.POSIXct(df$Time, format = "%d.%m.%Y :%H:%M", tz = "Asia/Kolkata")
。但我得到了 NA 值。这里有什么问题?
尝试 asPOSIXlt
:
> test <- "1.01.2016 0:00:05"
> as.POSIXlt(test, "%d.%m.%Y %H:%M:%S", tz="Asia/Kolkata")
[1] "2016-01-01 00:00:05 IST"
我怀疑这里有两件事在起作用:时间对象的存储 (POSIXt
),以及该对象的表示。
您提供的字符串(我相信)不是 R 的正确 POSIXt
(无论是 POSIXct
还是 POSIXlt
)对象,这意味着它只是一个字符串。在这种情况下,您可以使用以下方法将其删除:
gsub(':[^:]*$', '', '1.01.2016 0:00:05')
# [1] "1.01.2016 0:00"
但是,那仍然只是一个字符串,而不是日期或时间对象。如果将其解析为 R 知道的时间对象:
as.POSIXct("1.01.2016 0:00:05", format = "%d.%m.%Y %H:%M:%S", tz = "Asia/Kolkata")
# [1] "2016-01-01 00:00:05 IST"
然后你现在有一个 R 知道一些的时间对象......它默认以秒精度 表示 它(在控制台上打印它)。通常,控制台打印可以更改的只是秒的精度,如
options("digits.secs")
# $digits.secs
# NULL
Sys.time()
# [1] "2018-06-26 18:21:06 PDT"
options("digits.secs"=3)
Sys.time()
# [1] "2018-06-26 18:21:10.090 PDT"
那么你可以获得更多。但是,唉,我确实知道有一个 R 选项可以说 "always print my POSIXt
objects in this way"。所以你唯一的选择是(在你不再需要它成为类时间对象的时候)将它改回一个没有类时间值的字符串:
x <- as.POSIXct("1.01.2016 0:00:05", format = "%d.%m.%Y %H:%M:%S", tz = "Asia/Kolkata")
x
# [1] "2016-01-01 00:00:05 IST"
?strptime
# see that day-of-month can either be "%d" for 01-31 or "%e" for 1-31
format(x, format="%e.%m.%Y %H:%M")
# [1] " 1.01.2016 00:00"
(这同样适用于向量。)
我的一部分建议转换为 POSIXt
然后返回字符串而不是我的 gsub
示例,因为使用 as.POSIXct
会告诉您字符串何时与日期时间不匹配-like 对象,而 gsub
会很乐意做错事或什么都不做。
我的 df
中有一个 Time
列,其值为 1.01.2016 0:00:05
。我想要它没有秒数,因此使用了 df$Time <- as.POSIXct(df$Time, format = "%d.%m.%Y :%H:%M", tz = "Asia/Kolkata")
。但我得到了 NA 值。这里有什么问题?
尝试 asPOSIXlt
:
> test <- "1.01.2016 0:00:05"
> as.POSIXlt(test, "%d.%m.%Y %H:%M:%S", tz="Asia/Kolkata")
[1] "2016-01-01 00:00:05 IST"
我怀疑这里有两件事在起作用:时间对象的存储 (POSIXt
),以及该对象的表示。
您提供的字符串(我相信)不是 R 的正确 POSIXt
(无论是 POSIXct
还是 POSIXlt
)对象,这意味着它只是一个字符串。在这种情况下,您可以使用以下方法将其删除:
gsub(':[^:]*$', '', '1.01.2016 0:00:05')
# [1] "1.01.2016 0:00"
但是,那仍然只是一个字符串,而不是日期或时间对象。如果将其解析为 R 知道的时间对象:
as.POSIXct("1.01.2016 0:00:05", format = "%d.%m.%Y %H:%M:%S", tz = "Asia/Kolkata")
# [1] "2016-01-01 00:00:05 IST"
然后你现在有一个 R 知道一些的时间对象......它默认以秒精度 表示 它(在控制台上打印它)。通常,控制台打印可以更改的只是秒的精度,如
options("digits.secs")
# $digits.secs
# NULL
Sys.time()
# [1] "2018-06-26 18:21:06 PDT"
options("digits.secs"=3)
Sys.time()
# [1] "2018-06-26 18:21:10.090 PDT"
那么你可以获得更多。但是,唉,我确实知道有一个 R 选项可以说 "always print my POSIXt
objects in this way"。所以你唯一的选择是(在你不再需要它成为类时间对象的时候)将它改回一个没有类时间值的字符串:
x <- as.POSIXct("1.01.2016 0:00:05", format = "%d.%m.%Y %H:%M:%S", tz = "Asia/Kolkata")
x
# [1] "2016-01-01 00:00:05 IST"
?strptime
# see that day-of-month can either be "%d" for 01-31 or "%e" for 1-31
format(x, format="%e.%m.%Y %H:%M")
# [1] " 1.01.2016 00:00"
(这同样适用于向量。)
我的一部分建议转换为 POSIXt
然后返回字符串而不是我的 gsub
示例,因为使用 as.POSIXct
会告诉您字符串何时与日期时间不匹配-like 对象,而 gsub
会很乐意做错事或什么都不做。