Як об’єднати два кадри даних у r з різними стовпцями


Ви можете використовувати функцію bind_rows() із пакета dplyr у R, щоб швидко об’єднати два кадри даних із різними стовпцями:

 library (dplyr)

bind_rows(df1, df2)

У наступному прикладі показано, як використовувати цю функцію на практиці.

Приклад: об’єднайте два кадри даних з різними стовпцями

Припустимо, ми маємо наступні два кадри даних у R:

 #define first data frame
df1 <- data. frame (A=c(1, 6, 3, 7, 5),
                  B=c(7, 9, 8, 3, 2),
                  C=c(3, 5, 2, 9, 9))

df1

  ABC
1 1 7 3
2 6 9 5
3 3 8 2
4 7 3 9
5 5 2 9

#define second data frame
df2 <- data. frame (B=c(1, 3, 3, 4, 5),
                  C=c(7, 7, 8, 3, 2),
                  D=c(3, 3, 6, 6, 8))

df2

  BCD
1 1 7 3
2 3 7 3
3 3 8 6
4 4 3 6
5 5 2 8

Зауважте, що df1 має такі назви стовпців:

  • МАЄ
  • Б
  • ПРОТИ

І зауважте, що df2 має такі назви стовпців:

  • Б
  • ПРОТИ
  • Д

Назви стовпців не збігаються, тому функція rbind() у R видасть помилку, якщо ми спробуємо її використати.

 #attempt to use rbind to row bind data frames
rbind(df1, df2)

Error in match.names(clabs, names(xi)): 
  names do not match previous names

Замість цього ми можемо використовувати функцію bind_rows() з пакету dplyr, щоб об’єднати ці два кадри даних і просто заповнити відсутні значення в отриманому кадрі даних значеннями NA:

 library (dplyr)

#combine df1 and df2
bind_rows(df1, df2)

    ABCD
1 1 7 3 NA
2 6 9 5 NA
3 3 8 2 NA
4 7 3 9 NA
5 5 2 9 NA
6 NA 1 7 3
7 NA 3 7 3
8 NA 3 8 6
9 NA 4 3 6
10 NA 5 2 8

Додаткові ресурси

Як об’єднати два стовпці в один у R
Як скласти стовпці фрейму даних у R

Додати коментар

Ваша e-mail адреса не оприлюднюватиметься. Обов’язкові поля позначені *