在lapply中保存地块

我有一个数据框列表:

str(subsets.d)
List of 22
 $ 1       :'data.frame':   358 obs. of  118 variables:
  ..$ Ac_2017_1 : num [1:358] 0 0 0 0 0 0 0 0 0 0 ...
  ..$ Ac_9808_1 : num [1:358] 0 0 0 0 0 ...
  ..$ dates     : Ord.factor w/ 6 levels "April"<"May"<..: 1 1 1 1 1 1 1 
 $ 19      :'data.frame':   358 obs. of  2 variables:
  ..$ Ac_8598_19: num [1:358] 0.000257 0.000288 0.000171 0 0.000562 ...
  ..$ dates     : Ord.factor w/ 6 levels "April"<"May"<..: 1 1 1 1 1 1 1 

我继续将其转化为长格式:

library(reshape2)
subsets.m <- lapply(subsets.d, function(x) melt(x))

然后我想按日期制作箱型图:

library(ggplot2)
lapply(subsets.m, function(x)
  ggplot(x, aes(dates, value)) + geom_boxplot() + facet_wrap(~variable, scale="free_y"))

是否有可能把ggsave()pdf()放在乐谱里面或旁边? 如果是这样,我怎么才能根据数据框命名已保存的地块?

奖金问题,由于列表内的数据框具有不同的维度,所以地块的大小可能不同。 我可以为此调整吗?

以下是一些小例子数据:

dput(list1)
list(structure(list(Ac_7595_JG37 = c(0.000128383, 0.000576914, 
0.000341631, 0.000729133, 0.000187486, 0.00086127, 0.000594978, 
0.000631912, 0.000502274, 0.0004846, 0, 0.000148386, 0.000298153, 
0.000828969, 0.000436815, 7.28336e-05, 0.000304842, 0.000301909, 
0.000233694, 0.000208491), Ac_7474_JG37 = c(0, 0, 0.000512446, 
0, 0.000562457, 0, 0.000198326, 0.000473934, 0, 0.000138457, 
0.000132554, 0, 0.000198769, 0.000207242, 0.000145605, 0.000364168, 
0, 0.000301909, 0.000116847, 0), dates = structure(c(1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 
2L, 2L), .Label = c("April", "May", "June", "August", "October", 
"November"), class = c("ordered", "factor"))), .Names = c("Ac_7595_JG37", 
"Ac_7474_JG37", "dates"), row.names = c("1", "2", "3", "4", "5", 
"6", "7", "8", "9", "10", "61", "62", "63", "64", "65", "66", 
"67", "68", "69", "70"), class = "data.frame"), structure(list(
    Ac_8732_20 = c(0.000513534, 0.000384609, 0.000341631, 0.000729133, 
    0.000937429, 0.000322976, 0.000297489, 0.000394945, 0.000669698, 
    0.000346143, 0.000265108, 0.000296773, 0.000596306, 0.000310863, 
    0, 0.000509835, 0, 0.000301909, 0.000233694, 0), dates = structure(c(1L, 
    1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 2L, 2L), .Label = c("April", "May", "June", "August", 
    "October", "November"), class = c("ordered", "factor"))), .Names = c("Ac_8732_20", 
"dates"), row.names = c("1", "2", "3", "4", "5", "6", "7", "8", 
"9", "10", "61", "62", "63", "64", "65", "66", "67", "68", "69", 
"70"), class = "data.frame"))

你的图被存储在一个列表中,因此你可以在输出中使用lapply来保存所有的图。 这已经在这里得到了回答:通过他们的名字保存图表列表()

# create data for this example (data above too involved)
df <- data.frame(value = rnorm(100), dates = rep(1:50, 2), type = rep(c("a", "b")))
list1 <- split(df, df$type)


plots <- lapply(list1, function(x) ggplot(x, aes(dates, value)) + geom_boxplot())

lapply(names(plots), 
       function(x) ggsave(filename=paste(x,".jpeg",sep=""), plot=plots[[x]]))
链接地址: http://www.djcxy.com/p/31071.html

上一篇: Saving plots within lapply

下一篇: How to resize subviews of UIStackView in Xcode?