[R] Conditionally constructing columns in a data frame

David Winsemius dwinsemius at comcast.net
Tue Jun 29 21:36:00 CEST 2010


On Jun 29, 2010, at 2:54 PM, Stuart Luppescu wrote:

> Hello, I have to construct 5 new columns in a data frame depending on
> the value of another of the columns in the data frame. The only way I
> could figure out to do this was to subset the data frame five times,  
> do
> the variable construction, and then rbind the subsets back together.
> Here's part of the code I used:
>
> read001 <- read[read$=="001",]
>
>  read001$era1end <- NA
>  read001$era2base <- NA
>  read001$era2end <- NA
>  read001$era3base <- read001$era1base
>  read001$era3end <- read001$era3base + (6 * read001$era3tr)
>
> read011 <- read[read$existstr=="011",]
>
>  read011$era1end <- NA
>  read011$era2base <- read011$era1base
>  read011$era2end <- read011$era2base + (4 * read011$era2tr)
>  read011$era3base <- read011$era2end
>  read011$era3end <- read011$era2end + (6 * read011$era3tr)
>
> ...

?split

processed_list <- split(read, read$existstr)
# then you have the dataframe in sections determined by existstr's value
# process within groups (but your example does not generalize in an  
obvious manner.)
# then:
final <- do.call(rbind , processed_list)

-- 
David.
>
> read2 <- rbind(read001, read011, read100, read110, read111)
>
>
> Isn't there an easier way to do this?
>
> Thanks.
>
> -- 
> Stuart Luppescu <slu at ccsr.uchicago.edu>
> University of Chicago
>
> ______________________________________________
> R-help at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
> and provide commented, minimal, self-contained, reproducible code.

David Winsemius, MD
West Hartford, CT



More information about the R-help mailing list