Splitting and grouping plain text (grouping text by chapter in dataframe)?












0















I have a data frame/tibble where I've imported a file of plain text (txt). The text very consistent and is grouped by chapter. Sometimes the chapter text is only one row, sometimes it's multiple row. Data is in one column like this:



# A tibble: 10,708 x 1
x
<chr>
1 "Chapter 1 "
2 "Chapter text. "
3 "Chapter 2 "
4 "Chapter text. "
5 "Chapter 3 "
6 "Chapter text. "
7 "Chapter text. "
8 "Chapter 4 "


I'm trying to clean the data to have a new column for Chapter and the text from each chapter in another column, like this:



# A tibble: 10,548 x 2
x Chapter
<chr> <chr>
1 "Chapter text. " "Chapter 1 "
2 "Chapter text. " "Chapter 2 "
3 "Chapter text. " "Chapter 3 "
4 "Chapter text. " "Chapter 4 "


I've been trying to use regex to split the and group the data at each occurance of the word 'Chapter #' (chapter followed by a number, but cannot get the result I want. Any advice is much appreciated.










share|improve this question























  • is the order of rows 7 and 8 correct? or should it be reversed? or should there be "chapter text. " below row 8?

    – Shree
    Nov 21 '18 at 0:12


















0















I have a data frame/tibble where I've imported a file of plain text (txt). The text very consistent and is grouped by chapter. Sometimes the chapter text is only one row, sometimes it's multiple row. Data is in one column like this:



# A tibble: 10,708 x 1
x
<chr>
1 "Chapter 1 "
2 "Chapter text. "
3 "Chapter 2 "
4 "Chapter text. "
5 "Chapter 3 "
6 "Chapter text. "
7 "Chapter text. "
8 "Chapter 4 "


I'm trying to clean the data to have a new column for Chapter and the text from each chapter in another column, like this:



# A tibble: 10,548 x 2
x Chapter
<chr> <chr>
1 "Chapter text. " "Chapter 1 "
2 "Chapter text. " "Chapter 2 "
3 "Chapter text. " "Chapter 3 "
4 "Chapter text. " "Chapter 4 "


I've been trying to use regex to split the and group the data at each occurance of the word 'Chapter #' (chapter followed by a number, but cannot get the result I want. Any advice is much appreciated.










share|improve this question























  • is the order of rows 7 and 8 correct? or should it be reversed? or should there be "chapter text. " below row 8?

    – Shree
    Nov 21 '18 at 0:12
















0












0








0








I have a data frame/tibble where I've imported a file of plain text (txt). The text very consistent and is grouped by chapter. Sometimes the chapter text is only one row, sometimes it's multiple row. Data is in one column like this:



# A tibble: 10,708 x 1
x
<chr>
1 "Chapter 1 "
2 "Chapter text. "
3 "Chapter 2 "
4 "Chapter text. "
5 "Chapter 3 "
6 "Chapter text. "
7 "Chapter text. "
8 "Chapter 4 "


I'm trying to clean the data to have a new column for Chapter and the text from each chapter in another column, like this:



# A tibble: 10,548 x 2
x Chapter
<chr> <chr>
1 "Chapter text. " "Chapter 1 "
2 "Chapter text. " "Chapter 2 "
3 "Chapter text. " "Chapter 3 "
4 "Chapter text. " "Chapter 4 "


I've been trying to use regex to split the and group the data at each occurance of the word 'Chapter #' (chapter followed by a number, but cannot get the result I want. Any advice is much appreciated.










share|improve this question














I have a data frame/tibble where I've imported a file of plain text (txt). The text very consistent and is grouped by chapter. Sometimes the chapter text is only one row, sometimes it's multiple row. Data is in one column like this:



# A tibble: 10,708 x 1
x
<chr>
1 "Chapter 1 "
2 "Chapter text. "
3 "Chapter 2 "
4 "Chapter text. "
5 "Chapter 3 "
6 "Chapter text. "
7 "Chapter text. "
8 "Chapter 4 "


I'm trying to clean the data to have a new column for Chapter and the text from each chapter in another column, like this:



# A tibble: 10,548 x 2
x Chapter
<chr> <chr>
1 "Chapter text. " "Chapter 1 "
2 "Chapter text. " "Chapter 2 "
3 "Chapter text. " "Chapter 3 "
4 "Chapter text. " "Chapter 4 "


I've been trying to use regex to split the and group the data at each occurance of the word 'Chapter #' (chapter followed by a number, but cannot get the result I want. Any advice is much appreciated.







r nlp text-mining tidytext






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 20 '18 at 23:44









RyanRyan

404




404













  • is the order of rows 7 and 8 correct? or should it be reversed? or should there be "chapter text. " below row 8?

    – Shree
    Nov 21 '18 at 0:12





















  • is the order of rows 7 and 8 correct? or should it be reversed? or should there be "chapter text. " below row 8?

    – Shree
    Nov 21 '18 at 0:12



















is the order of rows 7 and 8 correct? or should it be reversed? or should there be "chapter text. " below row 8?

– Shree
Nov 21 '18 at 0:12







is the order of rows 7 and 8 correct? or should it be reversed? or should there be "chapter text. " below row 8?

– Shree
Nov 21 '18 at 0:12














1 Answer
1






active

oldest

votes


















1














Based on "Sometimes the chapter text is only one row, sometimes it's multiple row" I am assuming text in rows 6 and 7 belong to chapter 3 and there is no text for chapter 4 in your test data (Your desired output is probably a bit wrong).



Here's a way using dplyr and tidyr. Just run it piece-by-piece and you'll see how the data gets transformed.



df %>% 
mutate(
id = cumsum(grepl("[0-9].$", x)),
x = ifelse(grepl("[0-9].$", x), paste0(x, ":"), x)
) %>%
group_by(id) %>%
summarize(
chapter = paste0(x, collapse = "")
) %>%
separate(chapter, into = c("chapter", "text"), sep = ":", extra = "merge")

# A tibble: 4 x 3
id chapter text
<int> <chr> <chr>
1 1 "Chapter 1 " "Chapter text. "
2 2 "Chapter 2 " "Chapter text. "
3 3 "Chapter 3 " "Chapter text. Chapter text. "
4 4 "Chapter 4 " ""


Data -



df <- structure(list(x = c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", 
"Chapter text. ", "Chapter 3 ", "Chapter text. ", "Chapter text. ",
"Chapter 4 ")), .Names = "x", class = "data.frame", row.names = c(NA,
-8L))





share|improve this answer


























  • This works great, and you're right. I made a mistake in my example output (as you mentioned).

    – Ryan
    Nov 23 '18 at 18:18











  • I also realized that some of the chapters had periods following the numbers and some didn't. I edited the regex to be "Chapter [0-9]" and this seemed to fix the problem with this. Sometimes I have the Chapter # not on it's own row, but buried in text on another row. Any ideas how to handle that? An example from your Data (chapter 3): c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", "Chapter text. ", "This is some text. Chapter 3 ", "Chapter text. ", "Chapter text. ", "Chapter 4 "))

    – Ryan
    Nov 23 '18 at 18:25











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53403287%2fsplitting-and-grouping-plain-text-grouping-text-by-chapter-in-dataframe%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









1














Based on "Sometimes the chapter text is only one row, sometimes it's multiple row" I am assuming text in rows 6 and 7 belong to chapter 3 and there is no text for chapter 4 in your test data (Your desired output is probably a bit wrong).



Here's a way using dplyr and tidyr. Just run it piece-by-piece and you'll see how the data gets transformed.



df %>% 
mutate(
id = cumsum(grepl("[0-9].$", x)),
x = ifelse(grepl("[0-9].$", x), paste0(x, ":"), x)
) %>%
group_by(id) %>%
summarize(
chapter = paste0(x, collapse = "")
) %>%
separate(chapter, into = c("chapter", "text"), sep = ":", extra = "merge")

# A tibble: 4 x 3
id chapter text
<int> <chr> <chr>
1 1 "Chapter 1 " "Chapter text. "
2 2 "Chapter 2 " "Chapter text. "
3 3 "Chapter 3 " "Chapter text. Chapter text. "
4 4 "Chapter 4 " ""


Data -



df <- structure(list(x = c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", 
"Chapter text. ", "Chapter 3 ", "Chapter text. ", "Chapter text. ",
"Chapter 4 ")), .Names = "x", class = "data.frame", row.names = c(NA,
-8L))





share|improve this answer


























  • This works great, and you're right. I made a mistake in my example output (as you mentioned).

    – Ryan
    Nov 23 '18 at 18:18











  • I also realized that some of the chapters had periods following the numbers and some didn't. I edited the regex to be "Chapter [0-9]" and this seemed to fix the problem with this. Sometimes I have the Chapter # not on it's own row, but buried in text on another row. Any ideas how to handle that? An example from your Data (chapter 3): c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", "Chapter text. ", "This is some text. Chapter 3 ", "Chapter text. ", "Chapter text. ", "Chapter 4 "))

    – Ryan
    Nov 23 '18 at 18:25
















1














Based on "Sometimes the chapter text is only one row, sometimes it's multiple row" I am assuming text in rows 6 and 7 belong to chapter 3 and there is no text for chapter 4 in your test data (Your desired output is probably a bit wrong).



Here's a way using dplyr and tidyr. Just run it piece-by-piece and you'll see how the data gets transformed.



df %>% 
mutate(
id = cumsum(grepl("[0-9].$", x)),
x = ifelse(grepl("[0-9].$", x), paste0(x, ":"), x)
) %>%
group_by(id) %>%
summarize(
chapter = paste0(x, collapse = "")
) %>%
separate(chapter, into = c("chapter", "text"), sep = ":", extra = "merge")

# A tibble: 4 x 3
id chapter text
<int> <chr> <chr>
1 1 "Chapter 1 " "Chapter text. "
2 2 "Chapter 2 " "Chapter text. "
3 3 "Chapter 3 " "Chapter text. Chapter text. "
4 4 "Chapter 4 " ""


Data -



df <- structure(list(x = c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", 
"Chapter text. ", "Chapter 3 ", "Chapter text. ", "Chapter text. ",
"Chapter 4 ")), .Names = "x", class = "data.frame", row.names = c(NA,
-8L))





share|improve this answer


























  • This works great, and you're right. I made a mistake in my example output (as you mentioned).

    – Ryan
    Nov 23 '18 at 18:18











  • I also realized that some of the chapters had periods following the numbers and some didn't. I edited the regex to be "Chapter [0-9]" and this seemed to fix the problem with this. Sometimes I have the Chapter # not on it's own row, but buried in text on another row. Any ideas how to handle that? An example from your Data (chapter 3): c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", "Chapter text. ", "This is some text. Chapter 3 ", "Chapter text. ", "Chapter text. ", "Chapter 4 "))

    – Ryan
    Nov 23 '18 at 18:25














1












1








1







Based on "Sometimes the chapter text is only one row, sometimes it's multiple row" I am assuming text in rows 6 and 7 belong to chapter 3 and there is no text for chapter 4 in your test data (Your desired output is probably a bit wrong).



Here's a way using dplyr and tidyr. Just run it piece-by-piece and you'll see how the data gets transformed.



df %>% 
mutate(
id = cumsum(grepl("[0-9].$", x)),
x = ifelse(grepl("[0-9].$", x), paste0(x, ":"), x)
) %>%
group_by(id) %>%
summarize(
chapter = paste0(x, collapse = "")
) %>%
separate(chapter, into = c("chapter", "text"), sep = ":", extra = "merge")

# A tibble: 4 x 3
id chapter text
<int> <chr> <chr>
1 1 "Chapter 1 " "Chapter text. "
2 2 "Chapter 2 " "Chapter text. "
3 3 "Chapter 3 " "Chapter text. Chapter text. "
4 4 "Chapter 4 " ""


Data -



df <- structure(list(x = c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", 
"Chapter text. ", "Chapter 3 ", "Chapter text. ", "Chapter text. ",
"Chapter 4 ")), .Names = "x", class = "data.frame", row.names = c(NA,
-8L))





share|improve this answer















Based on "Sometimes the chapter text is only one row, sometimes it's multiple row" I am assuming text in rows 6 and 7 belong to chapter 3 and there is no text for chapter 4 in your test data (Your desired output is probably a bit wrong).



Here's a way using dplyr and tidyr. Just run it piece-by-piece and you'll see how the data gets transformed.



df %>% 
mutate(
id = cumsum(grepl("[0-9].$", x)),
x = ifelse(grepl("[0-9].$", x), paste0(x, ":"), x)
) %>%
group_by(id) %>%
summarize(
chapter = paste0(x, collapse = "")
) %>%
separate(chapter, into = c("chapter", "text"), sep = ":", extra = "merge")

# A tibble: 4 x 3
id chapter text
<int> <chr> <chr>
1 1 "Chapter 1 " "Chapter text. "
2 2 "Chapter 2 " "Chapter text. "
3 3 "Chapter 3 " "Chapter text. Chapter text. "
4 4 "Chapter 4 " ""


Data -



df <- structure(list(x = c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", 
"Chapter text. ", "Chapter 3 ", "Chapter text. ", "Chapter text. ",
"Chapter 4 ")), .Names = "x", class = "data.frame", row.names = c(NA,
-8L))






share|improve this answer














share|improve this answer



share|improve this answer








edited Nov 21 '18 at 0:49

























answered Nov 21 '18 at 0:32









ShreeShree

3,4561324




3,4561324













  • This works great, and you're right. I made a mistake in my example output (as you mentioned).

    – Ryan
    Nov 23 '18 at 18:18











  • I also realized that some of the chapters had periods following the numbers and some didn't. I edited the regex to be "Chapter [0-9]" and this seemed to fix the problem with this. Sometimes I have the Chapter # not on it's own row, but buried in text on another row. Any ideas how to handle that? An example from your Data (chapter 3): c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", "Chapter text. ", "This is some text. Chapter 3 ", "Chapter text. ", "Chapter text. ", "Chapter 4 "))

    – Ryan
    Nov 23 '18 at 18:25



















  • This works great, and you're right. I made a mistake in my example output (as you mentioned).

    – Ryan
    Nov 23 '18 at 18:18











  • I also realized that some of the chapters had periods following the numbers and some didn't. I edited the regex to be "Chapter [0-9]" and this seemed to fix the problem with this. Sometimes I have the Chapter # not on it's own row, but buried in text on another row. Any ideas how to handle that? An example from your Data (chapter 3): c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", "Chapter text. ", "This is some text. Chapter 3 ", "Chapter text. ", "Chapter text. ", "Chapter 4 "))

    – Ryan
    Nov 23 '18 at 18:25

















This works great, and you're right. I made a mistake in my example output (as you mentioned).

– Ryan
Nov 23 '18 at 18:18





This works great, and you're right. I made a mistake in my example output (as you mentioned).

– Ryan
Nov 23 '18 at 18:18













I also realized that some of the chapters had periods following the numbers and some didn't. I edited the regex to be "Chapter [0-9]" and this seemed to fix the problem with this. Sometimes I have the Chapter # not on it's own row, but buried in text on another row. Any ideas how to handle that? An example from your Data (chapter 3): c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", "Chapter text. ", "This is some text. Chapter 3 ", "Chapter text. ", "Chapter text. ", "Chapter 4 "))

– Ryan
Nov 23 '18 at 18:25





I also realized that some of the chapters had periods following the numbers and some didn't. I edited the regex to be "Chapter [0-9]" and this seemed to fix the problem with this. Sometimes I have the Chapter # not on it's own row, but buried in text on another row. Any ideas how to handle that? An example from your Data (chapter 3): c("Chapter 1 ", "Chapter text. ", "Chapter 2 ", "Chapter text. ", "This is some text. Chapter 3 ", "Chapter text. ", "Chapter text. ", "Chapter 4 "))

– Ryan
Nov 23 '18 at 18:25




















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53403287%2fsplitting-and-grouping-plain-text-grouping-text-by-chapter-in-dataframe%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Guess what letter conforming each word

Run scheduled task as local user group (not BUILTIN)

Port of Spain