繁体   English   中英

使用 purrr::map 在输出中获取多列

[英]Using purrr::map to get multiple columns in the output

数据

我有 2 个数据集:
* segments数据集表示路段( lhrs 。)
* hwys数据集表示包含单个lhrs的高速公路。

> segments
# A tibble: 1 x 5
   lhrs mto_collision_ref_number latitude longitude highway_number
  <dbl>                    <dbl>    <dbl>     <dbl>          <dbl>
1 10004                  1549630     42.9     -78.9              1 


> hwys
# A tibble: 5 x 3
  STREET          longitude latitude
  <fct>               <dbl>    <dbl>
1 HIGHWAY 3           -80.0     42.9
2 ADELAIDE AVE E      -78.9     43.9
3 HOWARD AVE          -83.0     42.2
4 HIGHWAY 12          -79.7     44.7
5 CORONATION BLVD     -80.3     43.4

问题

如您所见, segments数据集中缺少STREET列。 我想通过根据经度和纬度值查找给定lhrsSTREET之间的距离,在segments数据集中创建此列。 这意味着我需要将一lhrs 、纬度的lhrs与所有 5 个STREET位置进行比较,并找到距离最小的那个。 我认为这可以使用purrr包来完成。

我的代码

我可以使用geosphere::distVincentyEllipsoid()距离找到每个lhrsSTREET之间的距离,如下所示:

library(tidyverse)



segments_nested <- segments %>% group_by(mto_collision_ref_number) %>% nest()


segments_nested %>% 
  mutate(diztances = purrr::map(
    data, ~ distVincentyEllipsoid(hwys %>% select(longitude, latitude),
                                             c(.$longitude, .$latitude)))) %>% 
  unnest(.preserve = data)


# A tibble: 5 x 3
  mto_collision_ref_number data             diztances
                     <dbl> <list>               <dbl>
1                  1549630 <tibble [1 x 4]>    85316.
2                  1549630 <tibble [1 x 4]>   110700.
3                  1549630 <tibble [1 x 4]>   342921.
4                  1549630 <tibble [1 x 4]>   213961.
5                  1549630 <tibble [1 x 4]>   125547.  

但是,我仍然无法弄清楚如何将这些距离与STREET连接起来。 请指导我如何使用purrr::map来计算距离以及相应的STREET 一旦我有了它,我就可以group_by(mto_collision_ref_number)并获得summarize(min(diztances))

回家的一种方法是利用匿名函数的灵活性并使用它来返回一个已经符合规范的对象。 我用的组合group_by()transmute()

# this is setup for transmute() so we keep 'STREET' around
hwys <- group_by(hwys, STREET) 

segments_nested %>%
  mutate(results = purrr::map(
    data, ~ transmute(hwys, diztances = geosphere::distVincentyEllipsoid(c(longitude, latitude),
                                             c(.$longitude, .$latitude))))) %>% 
  unnest(results)

宾果游戏'STREET' 又回到了菜单男孩们

  mto_collision_ref_number STREET         diztances
                     <int> <chr>              <dbl>
1                  1549630 HIGHWAY3          89840.
2                  1549630 ADELAIDEAVEE     111101.
3                  1549630 HOWARDAVE        345569.
4                  1549630 HIGHWAY12        210099.
5                  1549630 CORONATIONBLVD   126702.

将来尝试以更易于重现的格式共享您的数据,我更喜欢read.table(text = )dput()也可以,如上所述。 我必须复制、粘贴和操作您的输出块才能将其放入 R:

segments <- read.table(
  text = "lhrs mto_collision_ref_number latitude longitude highway_number
  1 10004 1549630 42.9 -78.9 1",
  header = T,
  stringsAsFactors = F
)
hwys <- read.table(
  text = "  STREET longitude latitude
  1 HIGHWAY3 -80.0 42.9
  2 ADELAIDEAVEE  -78.9 43.9
  3 HOWARDAVE -83.0 42.2
  4 HIGHWAY12 -79.7 44.7
  5 CORONATIONBLVD -80.3 43.4",
  header = T, 
  stringsAsFactors = F
)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM