我正在尝试将页码添加到使用R中的绘图生成的pdf文件中,并以pdf格式保存。
我正在d_pply
使用我正在使用plot命令的data.frame
。
我认为d_pply
可以帮助我避免for
循环。以下是我原始数据中的样本以及更多因素。
data1 <- structure(list(fact = structure(c(1L, 1L, 1L, 1L, 1L, 1L, 1L,
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L,
2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 3L, 3L,
3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L
), .Label = c("A", "B", "C"), class = "factor"), speed = c(10.56,
11.94, 13.61, 15, 16.67, 18.06, 19.44, 20.28, 21.11, 21.67, 22.5,
23.06, 23.61, 24.44, 25, 25.56, 26.11, 26.94, 27.5, 15.83, 16.67,
17.5, 18.06, 18.89, 19.72, 20.56, 21.11, 21.94, 22.5, 23.33,
23.89, 24.44, 25, 25.56, 26.11, 26.67, 27.22, 8.61, 10.28, 11.94,
13.61, 15, 16.39, 17.5, 18.89, 19.72, 20.83, 21.67, 22.22, 22.5,
23.06, 23.61, 23.89, 23.89, 23.61)), .Names = c("fact", "speed"
), class = "data.frame", row.names = c(NA, -55L))
我尝试使用全局索引来完成任务。但我正在寻找一种有效的方法来做到这一点。 This one对我没有帮助。
index1 <<- 0
plot_pg <- function(x)
{ index1 <<- index1+1
plot(x$speed,main=paste0('pg# ',index1))
}
genplot <- function(df1,filename1)
{
pdfNAME <- paste0(name1,'.pdf')
pdf(pdfNAME)
d_ply(df1,c('fact'),function(x) plot_pg(x))
dev.off()
}
genplot(data1,'data1Plots')
更新
我应该在这里提一下,我会将我的data.frame
拆分为多个变量..像ddply(data,c('var1','var2'),function(x) MyplotFunc(x))
答案 0 :(得分:4)
我会这样做:
genplot <- function(df1,filename1){
pdfNAME <- paste0(filename1,'.pdf')
tmp <- split(df1,df1$fact)
pdf(pdfNAME)
for (i in seq_along(tmp)){
plot(tmp[[i]][,'speed'],main = paste0("pg#",i))
}
dev.off()
}
for
循环本身慢的想法是一个神话。问题是很容易陷入错误的编码技术里面 for循环,这使得你正在进行的操作需要很长时间。
在这种情况下,你在for循环中所做的只是绘图,所以我怀疑这与使用lapply
之类的内容之间存在很大的性能差异。需要注意的是增长对象(即附加)和修改对象,因为两者都会导致过度复制。