这是一个简化的例子。我的真实数据集非常大,所以答案在计算上应该是便宜的。
start.list <- list(cb_1 = c("VR_1", "VR_2", "VR_3"), cb_2 = c("VR_2", "VR_3", "VR_4"),
cb_3 = c("VR_3", "VR_4", "VR_5"))
> start.list
$cb_1
[1] "VR_1" "VR_2" "VR_3"
$cb_2
[1] "VR_2" "VR_3" "VR_4"
$cb_3
[1] "VR_3" "VR_4" "VR_5"所需输出列表:
> output.list
$VR_1
[1] "cb_1"
$VR_2
[1] "cb_1" "cb_2"
$VR_3
[1] "cb_1" "cb_2" "cb_3"
$VR_4
[1] "cb_2" "cb_3"
$VR_5
[1] "cb_3"发布于 2021-05-23 14:20:45
使用enframe和unnest -
tibble::enframe(start.list) %>%
tidyr::unnest(value) %>%
{split(.$name, .$value)}
#$VR_1
#[1] "cb_1"
#$VR_2
#[1] "cb_1" "cb_2"
#$VR_3
#[1] "cb_1" "cb_2" "cb_3"
#$VR_4
#[1] "cb_2" "cb_3"
#$VR_5
#[1] "cb_3"https://stackoverflow.com/questions/67656542
复制相似问题