如何解决使用函数和 lapply 制作正确标记的直方图
但是当我尝试使用函数和 lapply 创建显示数据分布的直方图时,xlab 没有给出感兴趣的变量的文本。相反,它使用感兴趣的变量的第一个值。我该如何解决这个问题?
我使用的代码如下:
# loads ggplot2 package
if(!require(ggplot2)){install.packages("ggplot2")} # ---- NOTE: relates to mlm analyses
# creates function_dataset_diamonds_DV_histogram
function_dataset_diamonds_DV_histogram <-
function(
DV_use
)
{
ggplot(diamonds,aes(x=as.numeric(DV_use))) +
geom_histogram(aes(y=..density..),alpha=0.5,position="identity",binwidth = nclass.Sturges(DV_use)) +
geom_density(alpha=.2) +
theme(legend.position="right") +
xlab(DV_use)
}
# tests function
function_dataset_diamonds_DV_histogram(diamonds$carat)
# applies function
lapply((diamonds[c(1,8:10)]),function_dataset_diamonds_DV_histogram)
解决方法
您将数据向量传递给 xlab,因此它只是将其截断为第一个值。你想传递一个字符串。
修改您的函数以获取标签值,然后使用 mapply
function_dataset_diamonds_DV_histogram <- function(DV_use,xLabel){
ggplot(diamonds,aes(x=as.numeric(DV_use))) +
geom_histogram(aes(y=..density..),alpha=0.5,position="identity",binwidth = nclass.Sturges(DV_use)) +
geom_density(alpha=.2) +
theme(legend.position="right") +
xlab(xLabel)
}
mapply(function_dataset_diamonds_DV_histogram,diamonds[c(1,8:10)],names(diamonds[c(1,8:10)]),SIMPLIFY = FALSE)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。