【问题标题】:`pivot_longer` operation - simpler way of achieving the expected output?`pivot_longer` 操作 - 实现预期输出的更简单方法?
【发布时间】:2020-12-20 12:03:23
【问题描述】:

我有一个df 的形式:

df <- tibble(
  id = c(1,2,3),
  val02 = c(0,1,0),
  val03 = c(1,0,0),
  val04 = c(0,1,1),
  age02 = c(1,2,3),
  age03 = c(2,3,4),
  age04 = c(3,4,5)
)

我想把它变成整洁的格式,比如:

# A tibble: 9 x 4
     id year    val   age
  <dbl> <chr> <dbl> <dbl>
1     1 02        0     1
2     1 03        1     2
3     1 04        0     3
4     2 02        1     2
5     2 03        0     3
6     2 04        1     4
7     3 02        0     3
8     3 03        0     4
9     3 04        1     5

使用两个单独的pivot_longer 操作和left_join 最后我实现了我想要的:

library(tidyverse)
df1 <- df %>%
  pivot_longer(cols = starts_with("val"), names_to = "year", values_to = "val", names_prefix = "val")
df2 <- df %>%
  pivot_longer(cols = starts_with("age"), names_to = "year", values_to = "age", names_prefix = "age")

left_join(df1, df2) %>%
  select(id, year, val, age)

然而,这似乎非常复杂。

我怎样才能简化这个操作?有没有办法一次性执行此操作? (在一个管道中..?)


【问题讨论】:

    标签: r dplyr tidyverse tidyr


    【解决方案1】:

    这取决于您的字符串(列名)的复杂性,但要给出一个想法:

    library(tidyverse)
    
    df %>%
      pivot_longer(-id,
                   names_to = c('.value', 'year'),
                   names_pattern = '([a-z]+)(\\d+)'
      )
    

    输出:

    # A tibble: 9 x 4
         id year    val   age
      <dbl> <chr> <dbl> <dbl>
    1     1 02        0     1
    2     1 03        1     2
    3     1 04        0     3
    4     2 02        1     2
    5     2 03        0     3
    6     2 04        1     4
    7     3 02        0     3
    8     3 03        0     4
    9     3 04        1     5
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2018-03-28
      • 1970-01-01
      • 2015-06-19
      • 2021-05-02
      • 1970-01-01
      • 2016-08-24
      • 2013-09-16
      相关资源
      最近更新 更多