Pytanie:
Czy istnieje sposób określenia formatu daty podczas używania argumentu colClasses w read.table / read.csv?
(Zdaję sobie sprawę, że mogę konwertować po zaimportowaniu, ale przy wielu kolumnach z datami takimi jak ta łatwiej byłoby to zrobić na etapie importu)
Przykład:
Mam plik .csv z kolumnami daty w formacie %d/%m/%Y
.
dataImport <- read.csv("data.csv", colClasses = c("factor","factor","Date"))
To źle powoduje konwersję. Na przykład 15/07/2008
staje się 0015-07-20
.
Powtarzalny kod:
data <-
structure(list(func_loc = structure(c(1L, 2L, 3L, 3L, 3L, 3L,
3L, 4L, 4L, 5L), .Label = c("3076WAG0003", "3076WAG0004", "3076WAG0007",
"3076WAG0009", "3076WAG0010"), class = "factor"), order_type = structure(c(3L,
3L, 1L, 1L, 1L, 1L, 2L, 2L, 3L, 1L), .Label = c("PM01", "PM02",
"PM03"), class = "factor"), actual_finish = structure(c(4L, 6L,
1L, 2L, 3L, 7L, 1L, 8L, 1L, 5L), .Label = c("", "11/03/2008",
"14/08/2008", "15/07/2008", "17/03/2008", "19/01/2009", "22/09/2008",
"6/09/2007"), class = "factor")), .Names = c("func_loc", "order_type",
"actual_finish"), row.names = c(NA, 10L), class = "data.frame")
write.csv(data,"data.csv", row.names = F)
dataImport <- read.csv("data.csv")
str(dataImport)
dataImport
dataImport <- read.csv("data.csv", colClasses = c("factor","factor","Date"))
str(dataImport)
dataImport
A oto jak wygląda wynik:
r
date
read.table
read.csv
Tommy O'Dell
źródło
źródło
read.table
i dodanieformat
argumentu, który jest przekazywany doas.Date
. Nie zdziwiłbym się jednak, gdyby istniał lepszy sposób, o którym nie myślę.Odpowiedzi:
Możesz napisać własną funkcję, która akceptuje ciąg i konwertuje go na datę przy użyciu żądanego formatu, a następnie użyj,
setAs
aby ustawić ją jakoas
metodę. Następnie możesz użyć swojej funkcji jako części colClasses.Próbować:
Następnie zmodyfikuj, jeśli to konieczne, aby pracować z danymi.
Edytować ---
Możesz
setClass('myDate')
najpierw uruchomić, aby uniknąć ostrzeżenia (możesz zignorować ostrzeżenie, ale może to być irytujące, jeśli będziesz to robić dużo, a jest to proste połączenie, które pozwala się go pozbyć).źródło
setMethod('myDate')
ma zrobić? Uruchamianie go powoduje po prostu błąd ...setClass
(teraz naprawione). ZapobiegasetAs
wysyłaniu ostrzeżenia o tym, że „myDate” nie istnieje jako klasa. Ostrzeżenie jest nieszkodliwe i wszystko nadal działa, ale ustawienie klasy oznacza, że nawet nie zobaczysz ostrzeżenia.Jeśli chcesz zmienić tylko jeden format daty, możesz użyć
Defaults
pakietu, aby zmienić domyślny format w ramachas.Date.character
Myślę, że odpowiedź @Greg Snow jest znacznie lepsza, ponieważ nie zmienia domyślnego zachowania często używanej funkcji.
źródło
Jeśli potrzebujesz czasu:
źródło
W międzyczasie problem został rozwiązany dawno temu przez Hadley Wickham. Tak więc w dzisiejszych czasach rozwiązanie sprowadza się do onelinera:
Może chcemy nawet pozbyć się niepotrzebnych rzeczy:
źródło