R没有显示来自json source

时间:2017-09-08 10:31:55

标签: json r windows utf-8 jsonlite

关于背景的一点点。 我从提供公共交通数据的API中提取数据。它以json格式返回结果,我使用库'jsonlite'处理它。

 resp <- GET(url = url)


  resp_char <- rawToChar(resp$content)
  parsed <- fromJSON(resp_char, flatten = T)

  parsed.df <- do.call(what = "rbind", args = lapply(parsed[1], as.data.frame))

问题是,结果中没有特殊字符。

我正在使用Windows Server 2012计算机,我在R中的语言设置如下所示:

    > Sys.getlocale()
[1] "LC_COLLATE=German_Germany.1252;LC_CTYPE=German_Germany.1252;LC_MONETARY=German_Germany.1252;LC_NUMERIC=C;LC_TIME=German_Germany.1252"

示例:

    > df$direction
"U Alt-Mariendorf (Berlin)" 
"U Alt-Tegel (Berlin)" 
"U Alt-Mariendorf (Berlin)"              
"U Alt-Tegel (Berlin)" 
"Märkisches Viertel, Wilhelmsruher Damm"

第五个结果的预期结果是“MärkischesViertel,Wilhelmsruher Damm”

之后我查看了实际编码。

> Encoding(df$direction)
   [1] "unknown" "unknown" "unknown" "unknown" "UTF-8"

在我看来,到目前为止看起来很不错,但是我看不到特殊字符。

我很感激有关这个问题的任何建议和想法。

此致

2 个答案:

答案 0 :(得分:2)

所以最后我明白了。 感谢@parth,它让我找到了正确的答案。 我在fromJSON语句之前使用了Encoding,这对我有用。

  resp <- GET(url = url)

  resp_char <- rawToChar(resp$content)
  Encoding(resp_char) <- "UTF-8"
  parsed <- fromJSON(resp_char, flatten = T)

  parsed.df <- do.call(what = "rbind", args = lapply(parsed[1], as.data.frame))

答案 1 :(得分:0)

使用数据框

df<-data.frame(direction=c("U Alt-Mariendorf (Berlin)","U Alt-Tegel (Berlin)","U Alt-Mariendorf (Berlin)","U Alt-Tegel (Berlin)","Märkisches Viertel, Wilhelmsruher Damm"), stringsAsFactors = FALSE)

> df
                                direction
1               U Alt-Mariendorf (Berlin)
2                    U Alt-Tegel (Berlin)
3               U Alt-Mariendorf (Berlin)
4                    U Alt-Tegel (Berlin)
5 Märkisches Viertel, Wilhelmsruher Damm

现在,只需将整个df$direction列的编码更改为

即可
Encoding(df$direction) <- "UTF-8"

修复了问题

> df
                               direction
1              U Alt-Mariendorf (Berlin)
2                   U Alt-Tegel (Berlin)
3              U Alt-Mariendorf (Berlin)
4                   U Alt-Tegel (Berlin)
5 Märkisches Viertel, Wilhelmsruher Damm