一种方法是利用
unlist()
. 这也将
F=c("G", "H")
和
F=list("G", "H")
以同样的方式对待。
以下示例不允许在节点名称中使用数字,并且节点名称必须是唯一的。这可能可以通过使用
rapply()
取而代之的是接近。
定义备选方案
squarebrackets
squarebracketsAlt <- function(inlist){
storeList <- unlist(inlist)
uniqueNames <- unique(unlist(strsplit(gsub("[0-9]", "", names(storeList)), "\\.")))
vecNames <- names(storeList)
storeVec <- paste0("[", storeList, "]")
names(storeVec) <- vecNames
for(i in uniqueNames){
whereBrack <- grep(paste0("\\.",i, "\\."),
paste0(".", gsub("[0-9]", "", names(storeVec)), "."))
storeVec <- append(storeVec, paste0("[", i), after=(whereBrack[1]-1))
storeVec <- append(storeVec, paste0("]") , after=(whereBrack[length(whereBrack)]+1))
}
cat(paste(storeVec, collapse=""))
}
在嵌套列表中尝试:
nestedlist <- list("A"=list("B"=45:50, "C"=LETTERS[21:26],
"D"=list("E"=7:10, "F"=list("G","H"))))
squarebracketsAlt(nestedlist)
输出:
[A[B[45][46][47][48][49][50]][C[U][V][W][X][Y][Z]][D[E[7][8][9][10]][F[G][H]]]]
较大层次结构示例:
nestedlist1 <- list("Ad fe"=list("B"=45:50, "C"=list("U"=letters[1:10],LETTERS[22:26]),
"D"=list("E"=7:10, "F"=list("G"=list("ZZ foo"=list("AA bar"=c(1:10),2,3,4,5)),"H", "C"))))
squarebracketsAlt(nestedlist1)
输出:
[Ad fe[B[45][46][47][48][49][50]][C[U[a][b][c][d][e][f][g][h][i][j]][V][W][X][Y][Z]][D[E[7][8][9][10]][F[G[ZZ foo[AA bar[1][2][3][4][5][6][7][8][9][10]][2][3][4][5]]][H][C]]]]
真实生活示例:
nestedlist2 <- list("Main Area"=
list("Fishing vessel"=c("trawler", "line", "skipper"), "Oil tanker"=c("Large", "Small", "Medium size"=
list("Barents Sea", "Norwegian Sea", "Kara Sea", "Greenland"))))
squarebracketsAlt(nestedlist2)
输出:
[Main Area[Fishing vessel[trawler][line][skipper]][Oil tanker[Large][Small][Medium size[Barents Sea][Norwegian Sea][Kara Sea][Greenland]]]]
前导数字示例:
squarebracketsAltNum <- function(inlist){
storeList <- unlist(inlist)
uniqueNames <- unique(paste(gsub("[A-z].*", "", unlist(strsplit(names(storeList), "\\."))),
unlist(strsplit(gsub("[0-9]", "", names(storeList)), "\\.")), sep=""))
vecNames <- names(storeList)
storeVec <- paste0("[", storeList, "]")
names(storeVec) <- vecNames
k <- 1
for(i in uniqueNames){
cat(i, "\n")
whereBrack <- grep(paste0("\\.",i),
paste0(".", names(storeVec)))
namePaster <- unique(paste(unlist(strsplit(gsub("[0-9]", "", names(storeList)), "\\.")),
gsub("[A-z].*", "", unlist(strsplit(names(storeList), "\\."))), sep=""))[k]
storeVec <- append(storeVec, paste0("[", namePaster), after=(whereBrack[1]-1))
storeVec <- append(storeVec, paste0("]") , after=(whereBrack[length(whereBrack)]+1))
k <- k+1
}
cat(paste(storeVec, collapse=""))
}
数字和单词/句子之间没有空格。摆弄regexp以修复:
nestedlist <- list("100A"=list("4B"=45:50, "3C"=LETTERS[21:26],
"D"=list("E"=7:10, "78F"=c("G","H"))))
squarebracketsAlt(nestedlist)
输出:
[A100[B4[45][46][47][48][49][50]][C3[U][V][W][X][Y][Z]][D[E[7][8][9][10]][F78[G][H]]]]