嵌套列表/ unnest_wider:逗号后丢失数字?

问题描述 投票:1回答:1

我正在下载一个json文件,该文件包含列表格式的坐标(水星格式)。当我打开生成的数据框/小标题时,我可以看到坐标具有小数位(逗号后的数字,例如.4,.58)。参见屏幕截图。

enter image description here

当我打印列表时,小数位丢失。取消嵌套列表时它们也丢失(tidyr :: unnest_wider)。知道这里发生了什么吗?我不明白为什么我在逗号后面看不到数字。非常感谢。

library(tidyverse)
library(jsonlite)
#> 
#> Attaching package: 'jsonlite'
#> The following object is masked from 'package:purrr':
#> 
#>     flatten

data_link <- "https://www.statistik.at/gs-atlas/ATLAS_SCHULE_WFS/ows?service=WFS&version=1.0.0&request=GetFeature&typeName=ATLAS_SCHULE_WFS:ATLAS_SCHULE&outputFormat=application%2Fjson&srsname=EPSG:3857&"

df <- jsonlite::fromJSON(data_link, flatten=TRUE) %>% 
  pluck("features") %>%  #extract nested list with data on schools
  select(id, geometry.coordinates) %>% 
  as_tibble()

class(df$geometry.coordinates)
#> [1] "list"
head(df$geometry.coordinates)
#> [[1]]
#> [1] 1816122 6131866
#> 
#> [[2]]
#> [1] 1819987 6131752
#> 
#> [[3]]
#> [1] 1808519 6129276
#> 
#> [[4]]
#> [1] 1810436 6132934
#> 
#> [[5]]
#> [1] 1834892 6142691
#> 
#> [[6]]
#> [1] 1830091 6147081

df %>% 
  head() %>% 
  mutate(geometry.coordinates=map(geometry.coordinates, set_names, c("long", "lat"))) %>% 
  unnest_wider(col = c("geometry.coordinates"))
#> # A tibble: 6 x 3
#>   id                                              long      lat
#>   <chr>                                          <dbl>    <dbl>
#> 1 ATLAS_SCHULE.fid--3c550d5d_1702f69fdc2_2a59 1816122. 6131866.
#> 2 ATLAS_SCHULE.fid--3c550d5d_1702f69fdc2_2a5a 1819987. 6131752.
#> 3 ATLAS_SCHULE.fid--3c550d5d_1702f69fdc2_2a5b 1808518. 6129276.
#> 4 ATLAS_SCHULE.fid--3c550d5d_1702f69fdc2_2a5c 1810436. 6132934.
#> 5 ATLAS_SCHULE.fid--3c550d5d_1702f69fdc2_2a5d 1834892. 6142691.
#> 6 ATLAS_SCHULE.fid--3c550d5d_1702f69fdc2_2a5e 1830091. 6147081.

reprex package(v0.3.0)在2020-02-10创建

r json list tidyr unnest
1个回答
0
投票
之后的数字

这更多是显示问题,可以使用options解决

options(digits = 12)

df$geometry.coordinates[[1]]
#[1] 1816122.40 6131865.58

并显示小标题,使用

options(pillar.sigfig = 12)

df %>% 
  head() %>% 
  mutate(geometry.coordinates=map(geometry.coordinates, set_names, c("long", "lat"))) %>% 
  unnest_wider(col = c("geometry.coordinates"))

# id                                                 long        lat
#  <chr>                                             <dbl>      <dbl>
#1 ATLAS_SCHULE.fid--3c550d5d_1702f7f16a0_-70d8 1816122.4  6131865.58
#2 ATLAS_SCHULE.fid--3c550d5d_1702f7f16a0_-70d7 1819987.4  6131752.22
#3 ATLAS_SCHULE.fid--3c550d5d_1702f7f16a0_-70d6 1808518.5  6129276.28
#4 ATLAS_SCHULE.fid--3c550d5d_1702f7f16a0_-70d5 1810435.84 6132934.36
#5 ATLAS_SCHULE.fid--3c550d5d_1702f7f16a0_-70d4 1834891.98 6142690.97
#6 ATLAS_SCHULE.fid--3c550d5d_1702f7f16a0_-70d3 1830091.28 6147080.61
© www.soinside.com 2019 - 2024. All rights reserved.