I have two data dfName
& dfTest
.
> dfName <- c("Ball", "Cat", "Dog")
> dfName
[1] "Ball" "Cat" "Dog"
I set name of first row of dfTest
as "Apple",
> dfTest <- data.frame(t(1:3))
> rownames(dfTest) <- "Apple"
> dfTest
X1 X2 X3
Apple 1 2 3
I want to append new rows to dfTest
and assign its rows' name using dfName
.
for(i in 1:3) {
dfTest <- rbind(dfTest, dfName[i] = data.frame(t(1:3)))
}
But it will retun this error,
Error: unexpected '=' in:
"for(i in 1:3) {
dfTest <- rbind(dfTest, dfName[i] ="
So I use rownames
as workaround,
for(i in 1:3) {
dfTest <- rbind(dfTest, data.frame(t(1:3)))
rownames(dfTest)[i+1] <- dfName[i]
}
> dfTest
X1 X2 X3
Apple 1 2 3
Ball 1 2 3
Cat 1 2 3
Dog 1 2 3
No issue if it's just a string variable,
> varA <- "Elephant"
> dfTest <- rbind(dfTest, varA = data.frame(t(1:3)))
> dfTest <- rbind(dfTest, "Flower" = data.frame(t(1:3)))
I know it's just one more line/function, but I wonder why I can't use dfName[i]
in rbind()
.
Edit: I can't use rownames(dfTest) <- dfName
because their number of rows don't match in my actual data.