Splitting and grouping plain text (grouping text by chapter in dataframe)?
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
add a comment |
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
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
add a comment |
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
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
r nlp text-mining tidytext
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
add a comment |
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
add a comment |
1 Answer
1
active
oldest
votes
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))
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
add a comment |
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
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
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))
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
add a comment |
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))
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
add a comment |
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))
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))
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
add a comment |
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
add a comment |
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.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
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
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