[R] simple question on data frames assignment
Michael Artz
michaeleartz at gmail.com
Thu Apr 7 16:31:18 CEST 2016
If you are not using an anonymous function and say you had written the
function out
The below gives me the error > 'f(colordata2$color1)' is not a function,
character or symbol' But then how is the anonymous function working?
f <- function(col){
ifelse(col == 'blue', 1, 0)
}
responses <- lapply(colordata2[ -1 ], f(colordata2$color1) )
'f(colordata2$color1)' is not a function, character or symbol'
then how could you then use this fuction in lapply if not for the anonymous
function?
On Thu, Apr 7, 2016 at 8:17 AM, Jeff Newmiller <jdnewmil at dcn.davis.ca.us>
wrote:
> Lapply is not a vectorized function. It is compact to read, but it would
> not be worth using for this calculation.
>
> However, if your data frame had multiple color columns in your data frame
> that you wanted to make responses for then you might want to use lapply as
> a more compact version of a for loop to repeat this operation.
>
> colordata2 <- data.frame(id = c(1,2,3,4,5), color1 = c("blue", "red",
> "green", "blue", "orange"), color2 = c("orange", "green",
> "blue", "red", "red"))
> responses <- lapply( colordata2[ -1 ], function(col) { ifelse(col ==
> 'blue', 1, 0) } )
> names(responses) <- names( colordata2 )[-1]
>
> where each of the columns other than the first is handed in turn to the
> anonymous function that does the response calculation. The result is a data
> frame (list of columns) with no column names, so I give the new columns
> names based on the old column names. You could choose different names, e.g.
>
> names(responses) <- paste0( "response", 1:2 )
>
> but you have to be careful to fix that code whenever you change the
> colordata2 data frame to have more columns.
> --
> Sent from my phone. Please excuse my brevity.
>
> On April 7, 2016 4:57:04 AM PDT, Michael Artz <michaeleartz at gmail.com>
> wrote:
>>
>> Thaks so much! And how would you incorporate lapply() here?
>>
>> On Thu, Apr 7, 2016 at 6:52 AM, David Barron <dnbarron at gmail.com> wrote:
>>
>> ifelse is vectorised, so just use that without the loop.
>>>
>>> colordata$response <- ifelse(colordata$color == 'blue', 1, 0)
>>>
>>> David
>>>
>>> On 7 April 2016 at 12:41, Michael Artz <michaeleartz at gmail.com> wrote:
>>>
>>> Hi I'm not sure how to ask this, but its a very easy question to answer
>>>> for
>>>> an R person.
>>>>
>>>> What is an easy way to check for a column value and then assigne a new
>>>> column a value based on that old column value?
>>>>
>>>> For example, Im doing
>>>> colordata <- data.frame(id = c(1,2,3,4,5),
>>>> color = c("blue", "red",
>>>> "green", "blue", "orange"))
>>>> for (i in 1:nrow(colordata)){
>>>> colordata$response[i] <- ifelse(colordata[i,"color"] == "blue", 1, 0)
>>>> }
>>>>
>>>> which works, but I don't want to use the for loop I want to "vecotrize"
>>>> this. How would this be implemented?
>>>>
>>>> [[alternative HTML version deleted]]
>>>>
>>>> ------------------------------
>>>>
>>>> R-help at r-project.org mailing list -- To UNSUBSCRIBE and more, see
>>>> 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.
>>>
>>>
>>>
>>
>> [[alternative HTML version deleted]]
>>
>> ------------------------------
>>
>> R-help at r-project.org mailing list -- To UNSUBSCRIBE and more, see
>> 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.
>>
>>
[[alternative HTML version deleted]]
More information about the R-help
mailing list