我有一个约561个元素的列表,每个元素都是一个列表,当调用时它看起来像一个矩阵。下面是从数据集的例子,R lapply访问列表中的元素并执行计算
structure(list(`111110` = structure(c(205, 4, 1, 6, 23, 0, 1,
0, 0), .Dim = c(3L, 3L), .Dimnames = list(c("1", "4", "5"), c("1",
"4", "5"))), `111120` = structure(c(181, 3, 4, 4), .Dim = c(2L,
2L), .Dimnames = list(c("1", "4"), c("1", "4"))), `111130` = structure(c(71, 8, 3, 15, 114, 7, 6, 8, 56), .Dim = c(3L, 3L), .Dimnames = list(
c("1", "4", "5"), c("1", "4", "5"))), `111140` = structure(c(87,
8, 9, 14), .Dim = c(2L, 2L), .Dimnames = list(c("1", "4"), c("1",
"4"))), `111150` = structure(24, .Dim = c(1L, 1L), .Dimnames = list(
"1", "1")), `111160` = structure(48, .Dim = c(1L, 1L), .Dimnames = list(
"1", "1"))), .Names = c("111110", "111120", "111130", "111140",
"111150", "111160"))
各元素的列表的尺寸是1×1至6×6,我想为每个列表中的元素执行以下计算:
如果条目有一个名为“5”的列,那么我想总结列“5”中的条目,除了列“5”的最后一行中的条目之外。如果没有列“5”,那么计算应该是空白的。
如果条目有一个名为“5”的列,那么列“1”中的元素总和除外,第一个元素除外。如果关联的条目没有包含“5”作为其标题的列,则它应该是空白的。
采取的计算部分1和2,并将它们添加到一个数据帧包含唯一ID和从1计算和2
我曾尝试以下(基于所提供的答案如下图):
output <- c()
for(x in names(trans.by.naics)) {
id <- x
count.entry.5 <- ifelse("5" %in% colnames(trans.by.naics[[x]]),
sum(trans.by.naics[[x]][1 :nrow(trans.by.naics[[x]]), 5]) - trans.by.naics[[x]][5,5], "") # sum down the first four rows of column "5" if it exists
count.entry.1 <- ifelse("5" %in% colnames(trans.by.naics[[x]]),
sum(trans.by.naics[[x]][1 : nrow(trans.by.naics[[x]]), 1]) - trans.by.naics[[x]][1,1], "")
thing <- data.frame(id, count.entry.5, count.entry.1)
output <- rbind(output, thing)
}
,但我得到以下运行我的代码:
Error in trans.by.naics[[x]][1:nrow(trans.by.naics[[x]]), 5] :
subscript out of bounds
期望的输出如下所示:
id count.entry.5 count.entry.1
1 111110 1 5
2 111120 3
3 111130 14 11
4 111140
5 111150
6 111160
是否有一种很好的方法可以做到这一点,不会花太长时间?也许更加矢量化的方法? lapply
方法?任何意见或帮助表示赞赏。谢谢!!
https://stackoverflow.com/questions/5963269/how-to-make-a-great-r-reproducible-example – AidanGawronski
@AidanGawronski非常感谢我不知道'dput的力量'举例来说。 – jvalenti