Ho il seguente vettore di valori doppi, x
, dove ogni elemento rappresenta un POSIX data tempoSemplificando un nodo POSIX con RJSONIO :: fromJSON()
x <- c(1417621083, 1417621204, 1417621384, 1417621564, 1417621623)
Sto usando il pacchetto RJSONIO, e vorrei continuare a farlo.
Come esercizio, mi piacerebbe convertire questi valori in testo JSON e poi leggerli di nuovo in R di nuovo, ma sto avendo problemi a ottenere le rappresentazioni di data e ora in un risultato di lista semplificata. In JSON, le date devono essere in un formato speciale in modo che i valori in x
vengono convertiti al seguente:
dates <- c("/new Date(1417621083)", "/Date(1417621204)", "/Date(1417621384)",
"/Date(1417621564)", "/Date(1417621623)")
Quando eseguo dates
con un secondo vettore arbitrario attraverso il RJSONIO parser, tutto sembra andare senza intoppi.
library(RJSONIO)
make <- toJSON(list(date = dates, value = LETTERS))
Quando poi analizzare il nuovo testo JSON utilizzando l'opzione stringFun
con il C routine di R-json per date, il risultato è una lista a due elementi, il primo elemento essendo un elenco e il secondo un vettore atomico .
(read <- fromJSON(make, stringFun = "R_json_dateStringOp"))
# $date
# $date[[1]]
# [1] "2014-12-03 07:38:03 PST"
#
# $date[[2]]
# [1] "2014-12-03 07:40:04 PST"
#
# $date[[3]]
# [1] "2014-12-03 07:43:04 PST"
#
# $date[[4]]
# [1] "2014-12-03 07:46:04 PST"
#
# $date[[5]]
# [1] "2014-12-03 07:47:03 PST"
#
#
# $value
# [1] "A" "B" "C" "D" "E" "F" "G" "H" "I" "J" "K" "L" "M"
# [14] "N" "O" "P" "Q" "R" "S" "T" "U" "V" "W" "X" "Y" "Z"
ma mi aspettavo un elenco di due vettori, e avrei preferito averlo in forma di
# $date
# [1] "2014-12-03 07:38:03 PST" "2014-12-03 07:40:04 PST"
# [3] "2014-12-03 07:43:04 PST" "2014-12-03 07:46:04 PST"
# [5] "2014-12-03 07:47:03 PST"
#
# $value
# [1] "A" "B" "C" "D" "E" "F" "G" "H" "I" "J" "K" "L" "M" "N" "O" "P" "Q"
# [18] "R" "S" "T" "U" "V" "W" "X" "Y" "Z"
Ho provato diversi modi per semplificare il risultato all'interno della chiamata a fromJSON()
, e nessuno di loro ha funzionato. Qui ci sono un paio di miei tentativi:
Utilizzando un gestore: Questo semplifica il risultato, ma non riesce a riformattare le date
h1 <- basicJSONHandler(simplify = TRUE)
fromJSON(make, handler = h1, stringFun = "R_json_dateStringOp")
# $date
# [1] "/new Date(1417621083)" "/Date(1417621204)"
# [3] "/Date(1417621384)" "/Date(1417621564)"
# [5] "/Date(1417621623)"
#
# $value
# [1] "A" "B" "C" "D" "E" "F" "G" "H" "I" "J" "K" "L" "M"
# [14] "N" "O" "P" "Q" "R" "S" "T" "U" "V" "W" "X" "Y" "Z"
Cercando l'argomentosimplify
: Ho provato diverse varietà di questo e nessuno ha funzionato.
fromJSON(make, simplify = StrictCharacter)
# $date
# [1] "/new Date(1417621083)" "/Date(1417621204)"
# [3] "/Date(1417621384)" "/Date(1417621564)"
# [5] "/Date(1417621623)"
#
# $value
# [1] "A" "B" "C" "D" "E" "F" "G" "H" "I" "J" "K" "L" "M"
# [14] "N" "O" "P" "Q" "R" "S" "T" "U" "V" "W" "X" "Y" "Z"
C'è un modo per semplificare il risultato per le date nella chiamata a fromJSON()
?