#' A function for counting words in an Rmarkdown/Quarto document.
#' taken from https://github.com/jvcasillas/academicWriteR/blob/master/R/count_words.R
#'
#' This function takes a path to a .Rmd file and returns a word count. For best
#' results each sentence should start on a new line. Inline code chunks should
#' also start on a new line.
#'
#' @param file A path to a .Rmd/.qmd file
#' @keywords Word count
#' @import dplyr
#' @export
#' @examples
#' # count_words("test.Rmd")
# Get word count
count_words <- function(file) {
wc <- readr::read_lines(file) %>%
tibble::as_tibble() %>%
remove_front_matter() %>%
remove_code_chunks() %>%
remove_inline_code() %>%
remove_html_comment() %>%
tidytext::unnest_tokens(output = words, input = value) %>%
nrow()
return(wc)
}
# Helper function for removing unwanted lines from count
# Checks is value is odd.
is_odd <- function(x, val) {
x %% 2 == 1
}
# Helper function to remove front matter (lines starting with "---" and
# anything between)
remove_front_matter <- function(x) {
mutate(x, is_code = cumsum(grepl("^---", value))) %>%
group_by(is_code) %>%
mutate(start_end = lag(is_code, 1)) %>%
ungroup() %>%
filter(!is_odd(is_code), !is.na(start_end)) %>%
select(-is_code, -start_end)
}
# Helper function for removing knitr code chunks (lines starting with "```"
# and anything in between)
remove_code_chunks <- function(x) {
mutate(x, is_code = cumsum(grepl("^```", value))) %>%
group_by(is_code) %>%
mutate(start_end = lag(is_code, 1)) %>%
ungroup() %>%
mutate(is_odd = is_odd(is_code)) %>%
filter(is_odd != TRUE, !is.na(start_end)) %>%
select(-is_code, -start_end, -is_odd)
}
# Helper function to remove inline code (lines starting with "`r")
remove_inline_code <- function(x) {
filter(x, !grepl("`r", value))
}
# Helper function to remove HTML comments (lines starting with "<!--" and "-->")
remove_html_comment <- function(x) {
mutate(x, start_comment = cumsum(grepl("^<!--", value)),
end_comment = cumsum(grepl("^-->", value))) %>%
group_by(start_comment, end_comment) %>%
mutate(start_end = lag(start_comment, 1)) %>%
ungroup() %>%
mutate(remove = if_else(start_comment - end_comment == 1 |
is.na(start_end), 1, 0)) %>%
filter(remove != TRUE) %>%
select(-start_comment, -end_comment, -remove)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.