【发布时间】:2014-08-09 17:29:48
【问题描述】:
我有这个函数可以从 .csv 文件中读取数据并将结果输出为 json 格式:
我的 vcenter.csv 文件如下所示:
Host Time Cpu
server1 1406284200 0.0920
server1 1406286000 0.0920
server1 1406287800 0.0912
server1 1406289600 0.0928
server1 1406291400 0.0912
server1 1406293200 0.0904
output<-function(myname){
library(rjson)
res<-read.csv("vcenter.csv", header=T, sep=',')
servers <- split(res, res$Host)
dumFun <- function(x){
sData <- servers[x][[1]]
if(nrow(sData) >0){
# create appropriate list
dumList <- unname(apply(sData[,2:3], 1, function(y) unname(as.list(y))))
return(toJSON(list(name = x, data = dumList)))
}
}
jsData <- lapply(names(servers), dumFun)
jsInd <- sapply(jsData, is.null)
p<-paste(jsData[!jsInd], collapse = ',')
p<-paste('[', p, ']')
print(p)
}
一个。当我远程调用此函数时,我得到如下信息:
[1] "[ {\"name\":\"server1\",\"data\":[[1406284200,0.387200012]
是否可以在输出中不显示 [1] 和 \ 值?
b.当我使用 RStudio 将此代码构建为包含 vcenter.csv 文件的包并安装该包时,当我运行 output.R 函数时,它看不到 vcenter.csv 文件。我应该把vcenter.csv放在哪里?我尝试将它放在库目录中,与 output.r 脚本相同的目录,不走运。我不断收到文件(文件,“rt”)连接错误。有什么想法吗?
【问题讨论】:
-
使用
cat()而不是print()来避免[1]。 -
@DirkEddelbuettel,当我使用 cat() 时,我在浏览器上收到 object not found 错误。但是,当我打印时,我得到了结果,但还有其他问题。除了 cat() 还有其他方法可以摆脱 [1] 吗?