mrip mrip - 1 year ago 913
R Question

Simplest way to get rbind to ignore column names

This came up just in an answer to another question here. When you

two data frames, it matches columns by name rather than index, which can lead to unexpected behavior:

> df<-data.frame(x=1:2,y=3:4)
> df
x y
1 1 3
2 2 4
> rbind(df,df[,2:1])
x y
1 1 3
2 2 4
3 1 3
4 2 4

Of course, there are workarounds. For example:


On edit:
from the
package doesn't actually work this way (although I thought I had it working when I originally wrote this...). The way to do this by renaming is to use SimonO101's solution:


Also, maybe surprisingly,


works by index (and if we don't mind a data table, then it's pretty concise), so this is a difference between

The question is, what is the most concise way to
two data frames where the names don't match? I know this seems trivial, but this kind of thing can end up cluttering code. And I don't want to have to write a new function called
. Ideally it would be something like

Answer Source

You might find setNames handy here...

rbind(df, setNames(rev(df), names(df)))
#  x y
#1 1 3
#2 2 4
#3 3 1
#4 4 2

I suspect your real use-case is somewhat more complex. You can of course reorder columns in the first argument of setNames as you wish, just use names(df) in the second argument, so that the names of the reordered columns match the original.