首页 > 解决方案 > 有没有办法从输入到 R 中的 toJSON 函数的数据框的输出中删除引号?

问题描述

我正在尝试将 R 中的数据框作为 json 文件输出,以用于我在 R 之外制作的高图。这就是我的输出的样子:-

[{"name":"alpha","value":1},{"name":"brave","value":2},{"name":"charlie","value":3}]

但是,我希望我的输出看起来像这样:-

[{name:"alpha",value:1},{name:"brave",value:2} {name:"charlie",value:3}] 

我应该怎么做才能不将我的数据框的名称(在本例中为名称和值)放在引号中?如果将我的数据转换为 json 文件不是最好的方法,我还能/应该做什么?

library(tidyverse)
library(jsonlite)
data = tibble(name = c("alpha", "bravo", "charlie"), 
              value = c(1, 2, 3))
output = toJSON(data, dataframe="rows")
write(output, "output.txt")

标签: rjsonjsonliter-highcharter

解决方案


一种可能的使用方法regex,从出现在冒号之前的值中删除引号:

json_string <- jsonlite::toJSON(data, dataframe="rows")

temp <- stringr::str_replace_all(json_string, '"(\\w+)"\\s*:', '\\1:')
cat(temp)
#[{name:"alpha",value:1},{name:"bravo",value:2},{name:"charlie",value:3}]

write(temp, "output.txt")

推荐阅读