English 中文(简体)
我如何使用pivot_longer和/或pivot_wider来调整我的数据?
原标题:How do I use pivot_longer and/or pivot_wider to restructure my data?

我有以下数据:

dat <- tribble(
~name,              ~current_hit,        ~future_hit, ~current_raw_power, ~future_raw_power, ~current_game_power, ~future_game_power,
"Jackson Holliday",           45,                 60,                 50,                60,                  25,                 60,
"James Wood",                 30,                 35,                 70,                80,                  55,                 80)

我期望的产出是:

player             names       current    future 
"Jackson Holliday" hit          45        60  
"Jackson Holliday" game_power   50        60   
"Jackson Holliday" raw_power    25        60
"James Wood"       hit          30        35
"James Wood"       raw_power    70        80
"James Wood"       game_power   55        80

I ve tried referencing a similar question here: pivot_longer into multiple columns. However, this use case is slightly different from mine and the use of regular expressions is a bit beyond my coding skills at the moment.

我的用意是,在后来的数据集中增加现时/未来数字,但我从一个更简单的例子开始,我可以据此扩大解决办法。

赞赏一切帮助!

问题回答
  dat %>% 
    pivot_longer(-name, names_to = "names") %>% 
    mutate(tmp = sub("(\w)_.*", "\1", names),
           names = sub("current_|future_", "", names)) %>% 
    pivot_wider(names_from = tmp, values_from = value) %>%
    rename(Player = name)

# A tibble: 6 × 4
      Player            names      current future
      <chr>            <chr>        <dbl>  <dbl>
    1 Jackson Holliday hit             45     60
    2 Jackson Holliday raw_power       50     60
    3 Jackson Holliday game_power      25     60
    4 James Wood       hit             30     35
    5 James Wood       raw_power       70     80
    6 James Wood       game_power      55     80




相关问题
How to plot fitted model over observed time series

This is a really really simple question to which I seem to be entirely unable to get a solution. I would like to do a scatter plot of an observed time series in R, and over this I want to plot the ...

REvolution for R

since the latest Ubuntu release (karmic koala), I noticed that the internal R package advertises on start-up the REvolution package. It seems to be a library collection for high-performance matrix ...

R - capturing elements of R output into text files

I am trying to run an analysis by invoking R through the command line as follows: R --no-save < SampleProgram.R > SampleProgram.opt For example, consider the simple R program below: mydata =...

R statistical package: wrapping GOFrame objects

I m trying to generate GOFrame objects to generate a gene ontology mapping in R for unsupported organisms (see http://www.bioconductor.org/packages/release/bioc/vignettes/GOstats/inst/doc/...

Changing the order of dodged bars in ggplot2 barplot

I have a dataframe df.all and I m plotting it in a bar plot with ggplot2 using the code below. I d like to make it so that the order of the dodged bars is flipped. That is, so that the bars labeled "...

Strange error when using sparse matrices and glmnet

I m getting a weird error when training a glmnet regression. invalid class "dgCMatrix" object: length(Dimnames[[2]]) must match Dim[2] It only happens occasionally, and perhaps only under larger ...

Generating non-duplicate combination pairs in R

Sorry for the non-descriptive title but I don t know whether there s a word for what I m trying to achieve. Let s assume that I have a list of names of different classes like c( 1 , 2 , 3 , 4 ) ...

Per panel smoothing in ggplot2

I m plotting a group of curves, using facet in ggplot2. I d like to have a smoother applied to plots where there are enough points to smooth, but not on plots with very few points. In particular I d ...

热门标签