as.Date功能,'格式'争论

时间:2016-09-11 12:54:41

标签: r date format as.date

我正在尝试使用as.Date函数将字符串转换为日期类值。我正在处理的字符串如下所示:

[1] "Sep 1, 2016"  "Aug 31, 2016" "Aug 30, 2016" "Aug 29, 2016" "Aug 26, 2016"
[6] "Aug 25, 2016" "Aug 24, 2016" "Aug 23, 2016" "Aug 22, 2016" "Aug 19, 2016"
[11] "Aug 18, 2016" "Aug 17, 2016" "Aug 16, 2016" "Aug 12, 2016" "Aug 11, 2016"
[16] "Aug 10, 2016" "Aug 9, 2016"  "Aug 8, 2016"  "Aug 5, 2016"  "Aug 4, 2016"
[21] "Aug 3, 2016"  "Aug 2, 2016"  "Aug 1, 2016"  "Jul 29, 2016" "Jul 28, 2016"
[26] "Jul 27, 2016" "Jul 26, 2016" "Jul 25, 2016" "Jul 22, 2016" "Jul 21, 2016"
[31] "Jul 20, 2016" "Jul 19, 2016" "Jul 18, 2016" "Jul 15, 2016" "Jul 14, 2016"
[36] "Jul 13, 2016" "Jul 12, 2016" "Jul 11, 2016" "Jul 8, 2016"  "Jul 7, 2016"

我为这个问题尝试了两个不同的代码,但它只是产生了NA。

as.Date("Sep 1, 2016",format="%b %d, %Y") #approach1
as.Date(gsub(",","","Sep 1, 2016"),format="%b %d %Y") #approach2
  1. 我尝试过的代码有什么问题?
  2. 此转换问题的正确代码是什么?
  3. 提前致谢。

2 个答案:

答案 0 :(得分:2)

我猜问题是你当前的语言环境

尝试临时。将其设置为C语言环境,如此

lct <- Sys.getlocale("LC_TIME"); 
Sys.setlocale("LC_TIME", "C")
as.Date("Sep 1, 2016",format="%b %d, %Y") #approach1
Sys.setlocale("LC_TIME", lct)  

有关详细信息,请参阅this问题+答案

答案 1 :(得分:0)

另一种可能性是使用R-package lubridate

install.packages("lubridate")

lubridate::mdy("Sep 1, 2016")

# [1] "2016-09-01"

使用函数mdy,因为第一个输入是月“m”,第二个是日“d”,第三个是年“y”。