0

次のようなデータフレームがあります。

dput(y)
structure(list(Name = c("Logon", "Logon", "Logon", "Logon", "Logon", 
"Logon", "Logon", "Logon", "Logon", "Logon", "Logon", "Logon", 
"Logon", "Logon", "Logon", "Logon", "Logon", "Logon", "Logon", 
"Logon"), MONTH = structure(c(15002, 15033, 15061, 15092, 15122, 
15153, 15183, 15214, 15245, 15275, 15306, 15336, 15367, 15398, 
15427, 15458, 15488, 15519, 15549, 15580), class = "Date"), TOTAL = c(284697404L, 
268944957L, 297847827L, 287150001L, 277779620L, 262275285L, 284271058L, 
294965702L, 285132804L, 238847338L, 242683830L, 314483537L, 324823553L, 
322896485L, 329044914L, 318228530L, 324395065L, 324988644L, 335464023L, 
336269471L)), .Names = c("Name", "MONTH", "TOTAL"), row.names = c(3755L, 
2875L, 3393L, 13558L, 14278L, 11991L, 12300L, 13040L, 47341L, 
36813L, 44897L, 46836L, 37038L, 46086L, 37261L, 37445L, 48030L, 
37486L, 38074L, 38818L), class = "data.frame")

このデータ フレームを次のような json 形式に変換する必要があります。

{"name":"Logon","data":[284697404,268944957,... ]}

私はこれを持っています:

servers <- split(y, y$Name)
dumFun <- function(x){
  sData <- servers[x][[1]]
  if(nrow(sData) >0){
    # create appropriate list
    dumList <- unname(apply(sData[3], 1, function(y) unname(as.list(y))))
    return(toJSON(list(name = x, data = dumList))) 
  }
}

jsData <- lapply(names(servers), dumFun)

これにより、データが次のように変換されます。

{"name":"Logon","data":[[284697404],[268944957],[297847827],[287150001],[277779620],[262275285],[284271058],[294965702],[285132804],[238847338],[242683830],[314483537],[324823553],[322896485],[329044914],[318228530],[324395065],[324988644],[335464023],[336269471],[324063033],[349017727],[347193478],[355561387],[373885187],[356774443],[386372600],[387573710],[397346365],[388064866],[397269760],[406584525],[353936952]]}"

出力を次のようにする必要があります。

{"name":"Logon","data":[284697404,268944957,297847827,287150001],...etc}"

何か案は?

4

2 に答える 2

1

dataリストではなくベクトルであるように見えます。ここにあなたの行:

dumList <- unname(apply(sData[3], 1, function(y) unname(as.list(y))))

データの 3 列目からリストを作成しています。これを次のように変更します。

dumList <- unname(apply(sData[3], 1, function(y) unname(y)))

または、さらに単純で同じ結果が得られます。

dumList <- sData[[3]]

何が起こっているのかを説明するにtoJSONは、単純なベクトル [1, 2, 3] と同じ要素のネストされたリストを変換する方法を見てください。

x <- 1:3
toJSON(x)
# [ 1, 2, 3 ]

x_list <- lapply(x, as.list)
toJSON(x_list)
# [ [1], [2], [3] ]

ここでの 2 番目のケースは、あなたが見ているものです。注意してください、ちょうどあなたのrjsonタグを見ました。RJSONIOパッケージを使用しています。ただし、使用している場合、結果は同じになるはずですrjson

于 2013-10-04T15:04:45.930 に答える