Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

tstrsplit function to strsplit *and* transpose to easily split + update columns directly. #1026

Closed
arunsrinivasan opened this issue Jan 27, 2015 · 1 comment
Assignees
Milestone

Comments

@arunsrinivasan
Copy link
Member

@arunsrinivasan arunsrinivasan commented Jan 27, 2015

This has come up quite frequently on SO. Here is one example.

Conceptually, tstrsplit() is just transpose(strsplit(...), fill=.) where transpose() is implemented in #1025.

require(data.table)
dt <- data.table(category.tag=c("toys/David", "toys/David", "toys/James", "toys", "toys", "toys/James"), transaction=1:6)
#    category.tag transaction
#1:   toys/David           1
#2:   toys/David           2
#3:   toys/James           3
#4:         toys           4
#5:         toys           5
#6:   toys/James           6
dt[, c("category", "tag") := tstrsplit(category.tag, "/", fixed=TRUE)]
#    category.tag transaction category   tag
#1:   toys/David           1     toys David
#2:   toys/David           2     toys David
#3:   toys/James           3     toys James
#4:         toys           4     toys    NA
#5:         toys           5     toys    NA
#6:   toys/James           6     toys James

Additionally we can also pass a fill = argument to tstrsplit.

@arunsrinivasan arunsrinivasan self-assigned this Jan 27, 2015
@arunsrinivasan arunsrinivasan added this to the v1.9.6 milestone Jan 27, 2015
@arunsrinivasan

This comment has been minimized.

Copy link
Member Author

@arunsrinivasan arunsrinivasan commented Jan 27, 2015

Updated this and this SO posts.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
1 participant
You can’t perform that action at this time.