I love the reshape2 package because it made life so doggone easy. Typically Hadley has made improvements in his previous packages that enable streamlined, faster running code. I figured I'd give tidyr a whirl and from what I read I thought gather was very similar to melt from reshape2. But after reading the documentation I can't get gather to do the same task that melt does.
Data View
Here's a view of the data (actual data in dput form at end of post):
teacher yr1.baseline pd yr1.lesson1 yr1.lesson2 yr2.lesson1 yr2.lesson2 yr2.lesson3 1 3 1/13/09 2/5/09 3/6/09 4/27/09 10/7/09 11/18/09 3/4/10 2 7 1/15/09 2/5/09 3/3/09 5/5/09 10/16/09 11/18/09 3/4/10 3 8 1/27/09 2/5/09 3/3/09 4/27/09 10/7/09 11/18/09 3/5/10 Code
Here's the code in melt fashion, my attempt at gather. How can I make gather do the same thing as melt?
library(reshape2); library(dplyr); library(tidyr) dat %>% melt(id=c("teacher", "pd"), value.name="date") dat %>% gather(key=c(teacher, pd), value=date, -c(teacher, pd)) Desired Output
teacher pd variable date 1 3 2/5/09 yr1.baseline 1/13/09 2 7 2/5/09 yr1.baseline 1/15/09 3 8 2/5/09 yr1.baseline 1/27/09 4 3 2/5/09 yr1.lesson1 3/6/09 5 7 2/5/09 yr1.lesson1 3/3/09 6 8 2/5/09 yr1.lesson1 3/3/09 7 3 2/5/09 yr1.lesson2 4/27/09 8 7 2/5/09 yr1.lesson2 5/5/09 9 8 2/5/09 yr1.lesson2 4/27/09 10 3 2/5/09 yr2.lesson1 10/7/09 11 7 2/5/09 yr2.lesson1 10/16/09 12 8 2/5/09 yr2.lesson1 10/7/09 13 3 2/5/09 yr2.lesson2 11/18/09 14 7 2/5/09 yr2.lesson2 11/18/09 15 8 2/5/09 yr2.lesson2 11/18/09 16 3 2/5/09 yr2.lesson3 3/4/10 17 7 2/5/09 yr2.lesson3 3/4/10 18 8 2/5/09 yr2.lesson3 3/5/10 Data
dat <- structure(list(teacher = structure(1:3, .Label = c("3", "7", "8"), class = "factor"), yr1.baseline = structure(1:3, .Label = c("1/13/09", "1/15/09", "1/27/09"), class = "factor"), pd = structure(c(1L, 1L, 1L), .Label = "2/5/09", class = "factor"), yr1.lesson1 = structure(c(2L, 1L, 1L), .Label = c("3/3/09", "3/6/09"), class = "factor"), yr1.lesson2 = structure(c(1L, 2L, 1L), .Label = c("4/27/09", "5/5/09"), class = "factor"), yr2.lesson1 = structure(c(2L, 1L, 2L), .Label = c("10/16/09", "10/7/09"), class = "factor"), yr2.lesson2 = structure(c(1L, 1L, 1L), .Label = "11/18/09", class = "factor"), yr2.lesson3 = structure(c(1L, 1L, 2L), .Label = c("3/4/10", "3/5/10"), class = "factor")), .Names = c("teacher", "yr1.baseline", "pd", "yr1.lesson1", "yr1.lesson2", "yr2.lesson1", "yr2.lesson2", "yr2.lesson3"), row.names = c(NA, -3L), class = "data.frame")
Melting in R programming is done to organize the data. It is performed using melt() function which takes dataset and column values that has to be kept constant. Using melt(), dataframe is converted into long format and stretches the data frame.
The melt() function in R programming is an in-built function. It enables us to reshape and elongate the data frames in a user-defined manner. It organizes the data values in a long data frame format.
The melt() function is used to convert a data frame with several measurement columns into a data frame in this canonical format, which has one row for every observed (measured) value. Let's melt data frame about states, with eight observations per row.
The melt function is to be found in the reshape package. If you do not have that package installed, then you will need to install it with install. packages("reshape") before you can use it. Then, when the package is installed, make it available with library(reshape) .
Your gather line should look like:
dat %>% gather(variable, date, -teacher, -pd) This says "Gather all variables except teacher and pd, calling the new key column 'variable' and the new value column 'date'."
As an explanation, note the following from the help(gather) page:
...: Specification of columns to gather. Use bare variable names. Select all variables between x and z with ‘x:z’, exclude y with ‘-y’. For more options, see the select documentation. Since this is an ellipsis, the specification of columns to gather is given as separate (bare name) arguments. We wish to gather all columns except teacher and pd, so we use -.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With