Помогите преобразовать char в POSIXlt
У меня много проблем с конвертацией char
data.frame в POSIXlt
, Это мое str
выход:
'data.frame': 5846 obs. of 5 variables:
$ date : Factor w/ 184 levels "1/1/2015","1/10/2015",..: 31 31 31 31 31 31 31 31 31 31 ...
$ time : Factor w/ 680 levels "1:00:00","1:01:00",..: 63 72 72 73 73 75 75 75 76 76 ...
$ morning: Factor w/ 2 levels "AM","PM": 2 2 2 2 2 2 2 2 2 2 ...
$ sender : Factor w/ 2 levels "Judith:","Saul": 2 1 1 2 2 1 2 2 1 1 ...
$ iso : chr "1/8/2014 10:10:00 PM" "1/8/2014 10:19:00 PM" "1/8/2014 10:19:00 PM" "1/8/2014 10:20:00 PM" ..
Я хочу конвертировать "ISO" в POSIXlt
с помощью
dat$iso <- strptime(dat$iso, "%d/%m/%Y %I:%M:%S %p")
Но я получаю NA
в следствии.
1 ответ
Решение
Я получаю аналогичный вывод при выполнении
> iso = "1/8/2014 10:19:00 PM"
> strptime(iso,"%d/%m/%Y %I:%M:%S %p")
[1] NA
Это из-за моей локали по умолчанию (fr_FR), которая не поддерживает%p. Изменение этой локали на "C" решает проблему:
> Sys.setlocale(category = "LC_TIME","C")
> strptime(iso,"%d/%m/%Y %I:%M:%S %p")
[1] "2014-08-01 22:19:00 CEST"