我需要粘贴两个字符向量中的所有元素组合,“每个”到“每个”:而不是
> paste0(c("a", "b"), c("c", "d"))
[1] "ac" "bd"
我想得到
[1] "ac" "ad" "bc" "bd"
我怎么做?
谢谢。
我需要粘贴两个字符向量中的所有元素组合,“每个”到“每个”:而不是
> paste0(c("a", "b"), c("c", "d"))
[1] "ac" "bd"
我想得到
[1] "ac" "ad" "bc" "bd"
我怎么做?
谢谢。
你也可以这样做:
outer(c("a", "b"), c("c", "d"), FUN = "paste0")[1:4]
[1] "ac" "bc" "ad" "bd"
两者都是有价值do.call
的outer
功能。:)
或者,我们可以分配
x <- outer(c("a", "b"), c("c", "d"), FUN = "paste0")
dim(x) <- NULL
x
[1] "ac" "bc" "ad" "bd"
不知长短。
更多编辑!
x <- outer(c("a", "b"), c("c", "d"), FUN = "paste0")
y <- t(x)
dim(y) <- NULL
y
[1] "ac" "ad" "bc" "bd"
也为您提供所需的订单。
尝试这个:
x <- c("a", "b")
y <- c("c", "d")
do.call(paste0, expand.grid(x, y))
# [1] "ac" "bc" "ad" "bd"
它可能比outer
whenx
和y
long 慢,但另一方面,它允许以下概括:
z <- c("e", "f")
do.call(paste0, expand.grid(x, y, z))
# [1] "ace" "bce" "ade" "bde" "acf" "bcf" "adf" "bdf"
另一个(不太常用的)咒语:
levels(interaction(x,y,sep=""))
# [1] "ac" "bc" "ad" "bd"
这也可以使用。
comb <- function(x,y)
{
x1 <- rep(x, each=length(y))
y1 <- rep(y, times=length(x))
paste0(x1,y1)
}
comb(2:4, 5:7)