• Skip to secondary menu
  • Skip to main content
  • Skip to primary sidebar

Python and R Tips

Learn Data Science with Python and R

  • Home
  • Python
  • Pandas
    • Pandas 101
  • tidyverse
    • tidyverse 101
  • R
  • Linux
  • Conferences
  • Python Books
  • About
    • Privacy Policy
You are here: Home / R / tidyverse / tidyr separate_rows() / How To Separate a Column into Multiple Rows with in R?

How To Separate a Column into Multiple Rows with in R?

June 9, 2019 by cmdlinetips

I just came across a useful little function in tidyr called separate_rows(). Often you may have a data frame with a column containing multiple information concatenated together with a delimiter. For example, we might have data frame with members of a family in a column separated by a delimiter. Here is a pictorial representation of separating a column into multiple rows. .
How to Separate A Column into Rows in R?

tidyr’s separate_rows() makes it easier to do it. Let us make a toy dataframe with multiple names in a column and see two examples of separating the column into multiple rows, first using dplyr’s mutate and unnest and then using the separate_rows() function from tidyr.

library(tidyverse)
df <- data.frame(Family_ID = 1:2,
  name = c("Smith, John", "Walker, Mike"),
  stringsAsFactors = FALSE)
df
##   Family_ID         name
## 1         1  Smith, John
## 2         2 Walker, Mike

How To Separate Column into Rows?

Let us first use mutate and unnest to split a column into multiple rows. We started with two rows and the name column had two names separated by comma.

We first split the name using strsplit as an argument to mutate function. Then we pass that to unnest to get them as separate rows.

df %>% 
    mutate(name=strsplit(name, ",")) %>% 
    unnest(name)

##   Family_ID   name
## 1         1  Smith
## 2         1   John
## 3         2 Walker
## 4         2   Mike

How To Separate Column into Rows with separate_rows()

Instead of using the hack of using mutate to create the same name with strsplit, mutate() and unnest(), we can use tidyr’s separate_rows() with column name that we want to split into multiple rows.

df %>% 
   separate_rows(name)
##   Family_ID   name
## 1         1  Smith
## 2         1   John
## 3         2 Walker
## 4         2   Mike

Share this:

  • Click to share on Facebook (Opens in new window) Facebook
  • Click to share on X (Opens in new window) X

Related posts:

Default ThumbnailHow to Filter a Pandas Dataframe Based on Null Values of a Column? Default ThumbnailHow to Recode a Column with dplyr in R? Default ThumbnailHow to Split a Single Column in Pandas into Multiple Columns Pandas explode(): Convert list-like column elements to separate rows

Filed Under: tidyr separate_rows() Tagged With: tidyr separate_rows()

Primary Sidebar

Subscribe to Python and R Tips and Learn Data Science

Learn Pandas in Python and Tidyverse in R

Tags

Altair Basic NumPy Book Review Data Science Data Science Books Data Science Resources Data Science Roundup Data Visualization Dimensionality Reduction Dropbox Dropbox Free Space Dropbox Tips Emacs Emacs Tips ggplot2 Linux Commands Linux Tips Mac Os X Tips Maximum Likelihood Estimation in R MLE in R NumPy Pandas Pandas 101 Pandas Dataframe Pandas Data Frame pandas groupby() Pandas select columns Pandas select_dtypes Python Python 3 Python Boxplot Python Tips R rstats R Tips Seaborn Seaborn Boxplot Seaborn Catplot Shell Scripting Sparse Matrix in Python tidy evaluation tidyverse tidyverse 101 Vim Vim Tips

RSS RSS

  • How to convert row names to a column in Pandas
  • How to resize an image with PyTorch
  • Fashion-MNIST data from PyTorch
  • Pandas case_when() with multiple examples
  • An Introduction to Statistical Learning: with Applications in Python Is Here
  • 10 Tips to customize ggplot2 title text
  • 8 Plot types with Matplotlib in Python
  • PCA on S&P 500 Stock Return Data
  • Linear Regression with Matrix Decomposition Methods
  • Numpy’s random choice() function

Copyright © 2025 · Lifestyle Pro on Genesis Framework · WordPress · Log in

Go to mobile version