English 中文(简体)
R: 将df栏目作为习惯功能的投入
原标题:R: Use column name of df as input for custom function

我正试图使一种习惯功能,而这种功能则需要参考,而我所希望的那一栏的名称则需要适用。 然而,我却在忙于要求我履行职责。

When I enter the name of the column without parentheses, I get "Error: object Area not found". When I enter the column name as a character, I get "Error in model.frame.default(form, data) : variable lengths differ (found for Treatment )".

我猜测,我需要在本职能范围内重塑我的栏目,但我不知道需要做些什么。

AssumTests <- function(data, aspect){
  # Homogeneity of Variance test
  lt <- leveneTest(aspect ~ Treatment, 
             data = data)
  
  model  <- lm(aspect ~ Treatment, data = data)
  
  # Normality residuals as group
  qq <- ggqqplot(residuals(model))
  st <- shapiro_test(residuals(model))
  
  # Normality test by group
  qqfac <- ggqqplot(data, paste(aspect), facet.by = "Treatment")
  spfac <- data %>%
    group_by(Treatment) %>%
    shapiro_test(aspect)
  
  list = list(lt, qq, st, qqfac, spfac)
  return(list)
}
AssumTests(FluorByTreatment_Iter1.df, "Area")

Crossposted to:

UPDATE: Got the first expressions to work with data[[aspect]], but still having trouble with the last expression using dplyr piping. I tried the {{aspect}} trick, but R is still recognizing the quotes: "Column "Area" doesn t exist."

UPDATE2: Got the final expression to work, through this !

问题回答

头3个用语必须使用!

最终守则是:

AssumTests <- function(data, aspect){
  # Homogeneity of Variance test
  lt <- leveneTest(data[[aspect]] ~ Treatment, 
             data = data)
  
  model  <- lm(data[[aspect]] ~ Treatment, data = data)
  
  # Normality residuals as group
  qq <- ggqqplot(residuals(model))
  st <- shapiro_test(residuals(model))
  
  # Normality test by group
  qqfac <- ggqqplot(data, aspect, facet.by = "Treatment")
  spfac <- data %>%
    group_by(Treatment) %>%
    shapiro_test(!!sym(aspect))
  
  list = list(lt, qq, st, qqfac, spfac)
  return(list)




相关问题
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 ...

热门标签