diff --git a/DESCRIPTION b/DESCRIPTION index d744d6a..4332a87 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -47,5 +47,5 @@ VignetteBuilder: Encoding: UTF-8 Language: en-US Roxygen: list(markdown = TRUE) -RoxygenNote: 7.1.1 +RoxygenNote: 7.1.2 SystemRequirements: pandoc (>= 2.0.6) - http://pandoc.org diff --git a/NEWS.md b/NEWS.md index cc73575..a0bef17 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,6 +1,7 @@ # ftExtra 0.3.0.9999 * `as_paragraph_md` supports empty string, `""`, as an input (#68). +* Improved support for the underline syntax in Pandoc's Markdown (#73). # ftExtra 0.3.0 diff --git a/R/as-paragraph-md.R b/R/as-paragraph-md.R index 49bdbb3..d067b78 100644 --- a/R/as-paragraph-md.R +++ b/R/as-paragraph-md.R @@ -52,7 +52,7 @@ construct_chunk <- function(x, auto_color_link = "blue") { width = image_size(x$Image, "width"), height = image_size(x$Image, "height"), vertical.align = vertical_align(x$Superscript, x$Subscript), - underlined = x$underlined %||% NA, + underlined = x$Underline %||% NA, color = x$color %||% NA_character_, shading.color = x$shading.color %||% NA_character_, font.family = x$font.family %||% NA_character_ diff --git a/R/md2df.R b/R/md2df.R index 6780d64..2a03176 100644 --- a/R/md2df.R +++ b/R/md2df.R @@ -112,7 +112,7 @@ format_by_attr <- function(x) { if(length(a) == 0L) return(x) - x$underlined = any(a$class == "underline") + x$Underline = any(x$Underline, a$class == "underline") x$color = last(a$color) %||% NA_character_ x$shading.color = last(a$shading.color) %||% NA_character_ x$font.family = last(a$font.family) %||% NA_character_ diff --git a/docs/404.html b/docs/404.html index 8551d5f..2f91119 100644 --- a/docs/404.html +++ b/docs/404.html @@ -1,66 +1,27 @@ - - - - + + + + - Page not found (404) • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + - - - - -
-
- + +
+ + + - - -
+
+
-
+ + - - diff --git a/docs/LICENSE-text.html b/docs/LICENSE-text.html index 3232a77..0ccc7cc 100644 --- a/docs/LICENSE-text.html +++ b/docs/LICENSE-text.html @@ -1,66 +1,12 @@ - - - - - - - -License • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -License • ftExtra - + + - - - -
-
- -
- -
+
+
-
- +
- - + + diff --git a/docs/LICENSE.html b/docs/LICENSE.html index 530158e..6d10fd7 100644 --- a/docs/LICENSE.html +++ b/docs/LICENSE.html @@ -1,66 +1,12 @@ - - - - - - - -MIT License • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -MIT License • ftExtra - + + - - - -
-
- -
- -
+
+
-
- +
- - + + diff --git a/docs/articles/format_columns.html b/docs/articles/format_columns.html index efe65bd..bc932f6 100644 --- a/docs/articles/format_columns.html +++ b/docs/articles/format_columns.html @@ -19,6 +19,8 @@ + +
+
@@ -101,31 +97,36 @@

Format columns as markdown

This vignette introduces how to format columns in flextable.

-
-

-Why markdown?

-

The flextable package is an excellent package that allows fine controls on styling tables, and export it to variety of formats (HTML, MS Word, PDF). Especially, when output format is MS Word, this package is the best solution in R.

-

On the other hand, styling texts with the flextable package often require large efforts. The following example subscripts numeric values in chemical formulas.

+library(flextable) +library(ftExtra)
+
+

Why markdown? +

+

The flextable package is an excellent package that +allows fine controls on styling tables, and export it to variety of +formats (HTML, MS Word, PDF). Especially, when output format is MS Word, +this package is the best solution in R.

+

On the other hand, styling texts with the flextable +package often require large efforts. The following example subscripts +numeric values in chemical formulas.

-df <- data.frame(Oxide = c("SiO2", "Al2O3"), stringsAsFactors = FALSE)
-ft <- flextable::flextable(df)
+df <- data.frame(Oxide = c("SiO2", "Al2O3"), stringsAsFactors = FALSE)
+ft <- flextable::flextable(df)
 
-ft %>%
-  flextable::compose(
+ft %>%
+  flextable::compose(
     i = 1, j = "Oxide",
-    value = flextable::as_paragraph(
-      "SiO", as_sub("2")
+    value = flextable::as_paragraph(
+      "SiO", as_sub("2")
     )
-  ) %>%
-  flextable::compose(
+  ) %>%
+  flextable::compose(
     i = 2, j = "Oxide",
-    value = flextable::as_paragraph(
-      "Al", as_sub("2"), "O", as_sub("3")
+    value = flextable::as_paragraph(
+      "Al", as_sub("2"), "O", as_sub("3")
     )
   )
-
+

The ftExtra package provides easy solution by introducing markdown. As markdown texts self-explain their formats by plain texts, what users have to do is manipulations of character columns with their favorite tools such as the famous dplyr and stringr packages.

+

The ftExtra package provides easy solution by +introducing markdown. As markdown texts self-explain their formats by +plain texts, what users have to do is manipulations of character columns +with their favorite tools such as the famous dplyr and +stringr packages.

  1. Preprocess a data frame to decorate texts with markdown syntax.
  2. -
  3. Convert the data frame into a flextable object with the flextable function or as_flextable function.
  4. +
  5. Convert the data frame into a flextable object with the +flextable function or as_flextable +function.
  6. Format markdown columns with colformat_md

The following example elegantly simplifies the prior example.

-df <- data.frame(Oxide = c("SiO2", "Fe2O3"), stringsAsFactors = FALSE)
+df <- data.frame(Oxide = c("SiO2", "Fe2O3"), stringsAsFactors = FALSE)
 
-df %>%
-  dplyr::mutate(Oxide = stringr::str_replace_all(Oxide, "([2-9]+)", "~\\1~")) %>%
-  flextable::flextable() %>%
+df %>%
+  dplyr::mutate(Oxide = stringr::str_replace_all(Oxide, "([2-9]+)", "~\\1~")) %>%
+  flextable::flextable() %>%
   ftExtra::colformat_md()
-
+

The colformat_md function is smart enough to detect character columns, so users can start without learning its arguments. Of course, it is possible to chose columns.

-

Another workflow is to read a markdown-formatted table from a external file. Again, markdown is by design a plain text, and can easily be embed in any formats such as CSV and Excel. So users can do something like

+

The colformat_md function is smart enough to detect +character columns, so users can start without learning its arguments. Of +course, it is possible to chose columns.

+

Another workflow is to read a markdown-formatted table from a +external file. Again, markdown is by design a plain text, and can easily +be embed in any formats such as CSV and Excel. So users can do something +like

-readr::read_csv("example.csv") %>%
-  flextable::flextable() %>%
+readr::read_csv("example.csv") %>%
+  flextable::flextable() %>%
   ftExtra::colformat_md()
-

By default, the ftExtra package employs Pandoc’s markdown, which is also employed by R Markdown. This enables consistent user experience when using the ftExtra package in R Markdown.

+

By default, the ftExtra package employs Pandoc’s +markdown, which is also employed by R Markdown. This enables consistent +user experience when using the ftExtra package in R +Markdown.

-
-

-Basic examples

-

The example below shows that colformat_md() function parses markdown texts in the flextable object.

+
+

Basic examples +

+

The example below shows that colformat_md() function +parses markdown texts in the flextable object.

-data.frame(
-  a = c("**bold**", "*italic*"),
-  b = c("^superscript^", "~subscript~"),
-  c = c("`code`", "[underline]{.underline}"),
-  d = c("*[**~ft~^Extra^**](https://ftextra.atusy.net/) is*",
+data.frame(
+  a = c("**bold**", "*italic*"),
+  b = c("^superscript^", "~subscript~"),
+  c = c("`code`", "[underline]{.underline}"),
+  d = c("*[**~ft~^Extra^**](https://ftextra.atusy.net/) is*",
         "[Cool]{.underline shading.color='skyblue'}"),
   stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
+) %>%
+  as_flextable() %>%
   colformat_md()
-
+

The table header can also be formatted by specifying part = "header" or "all" to colformat_md()

+

The table header can also be formatted by specifying +part = "header" or "all" to +colformat_md()

Supported syntax are

  • bold
  • @@ -476,23 +499,25 @@

    Notes:

    • other syntax may result in unexpected behaviors.
    • -
    • multiple paragraphs are collapsed to a single paragraph with a separator given to the .sep argument (default: "\n\n").
    • +
    • multiple paragraphs are collapsed to a single paragraph with a +separator given to the .sep argument (default: +"\n\n").

-
-

-Footnotes

+
+

Footnotes +

An easy way to add a footnote is inline footnote.

-data.frame(
+data.frame(
   package = "ftExtra",
   description = "Extensions for 'Flextable'^[Supports of footnotes]",
   stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
-  colformat_md() %>%
-  flextable::autofit(add_w = 0.5)
-
+

Reference symbols can be configured by footnote_options(). Of course, markdown can be used inside footnotes as well.

+

Reference symbols can be configured by +footnote_options(). Of course, markdown can be used inside +footnotes as well.

-data.frame(
+data.frame(
   package = "ftExtra^[Short of *flextable extra*]",
   description = "Extensions for 'Flextable'^[Supports of footnotes]",
   stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
+) %>%
+  as_flextable() %>%
   colformat_md(
     .footnote_options = footnote_options(ref = "i",
                                          prefix = '[',
@@ -569,9 +596,9 @@ 

start = 2, inline = TRUE, sep = "; ") - ) %>% - flextable::autofit(add_w = 0.5)

-
+

In order to add multiple footnotes to a cell, use normal footnotes syntax.

+

In order to add multiple footnotes to a cell, use normal footnotes +syntax.

-data.frame(x = 
+data.frame(x = 
 "foo[^a]^,^ [^b]
 
 [^a]: aaa
 
 [^b]: bbb",
 stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
+) %>%
+  as_flextable() %>%
   colformat_md()
-
+
-
-

-Images

-

Images can be inserted optionally with width and/or height attributes. Specifying one of them changes the other while keeping the aspect ratio.

+
+

Images +

+

Images can be inserted optionally with width and/or height +attributes. Specifying one of them changes the other while keeping the +aspect ratio.

-data.frame(
-  R = sprintf("![](%s)", file.path( R.home("doc"), "html", "logo.jpg" )),
+data.frame(
+  R = sprintf("![](%s)", file.path( R.home("doc"), "html", "logo.jpg" )),
   stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
-  colformat_md() %>%
-  flextable::autofit()
-
+

The R logo is distributed by The R Foundation with the CC-BY-SA 4.0 license.

+

The R logo is distributed by The R Foundation with the CC-BY-SA 4.0 +license.

-
-

-Line breaks

+
+

Line breaks +

By default, soft line breaks becomes spaces.

-data.frame(linebreak = c("a\nb"), stringsAsFactors = FALSE) %>%
-  as_flextable() %>%
+data.frame(linebreak = c("a\nb"), stringsAsFactors = FALSE) %>%
+  as_flextable() %>%
   colformat_md()
-
+

Pandoc’s markdown supports hard line breaks by adding a backslash or double spaces at the end of a line.

+

Pandoc’s markdown supports hard line breaks by adding a backslash or +double spaces at the end of a line.

-data.frame(linebreak = c("a\\\nb"), stringsAsFactors = FALSE) %>%
-  as_flextable() %>%
+data.frame(linebreak = c("a\\\nb"), stringsAsFactors = FALSE) %>%
+  as_flextable() %>%
   colformat_md()
-
+

It is also possible to make \n as a hard line break by extending Pandoc’s Markdown.

+

It is also possible to make \n as a hard line break by +extending Pandoc’s Markdown.

-data.frame(linebreak = c("a\nb"), stringsAsFactors = FALSE) %>%
-  as_flextable() %>%
+data.frame(linebreak = c("a\nb"), stringsAsFactors = FALSE) %>%
+  as_flextable() %>%
   colformat_md(md_extensions = "+hard_line_breaks")
-
+

Markdown treats continuous linebreaks as a separator of blocks such as paragraphs. However, flextable package lacks the support for multiple paragraphs in a cell. To workaround, colformat_md collapses them to a single paragraph with a separator given to .sep (default: \n\n).

+

Markdown treats continuous linebreaks as a separator of blocks such +as paragraphs. However, flextable package lacks the +support for multiple paragraphs in a cell. To workaround, +colformat_md collapses them to a single paragraph with a +separator given to .sep (default: \n\n).

-data.frame(linebreak = c("a\n\nb"), stringsAsFactors = FALSE) %>%
-  as_flextable() %>%
+data.frame(linebreak = c("a\n\nb"), stringsAsFactors = FALSE) %>%
+  as_flextable() %>%
   colformat_md(.sep = "\n\n")
-
+
-
-

-Citations

-

Citations is experimentally supported. Note that there are no citation lists. It is expected to be produced by using R Markdown.

+
+

Citations +

+

Citations is experimentally supported. Note that there are no +citation lists. It is expected to be produced by using R Markdown.

First, create a ftExtra.bib file like below.

-
@Manual{R-ftExtra,
-  title = {ftExtra: Extensions for Flextable},
-  author = {Atsushi Yasumoto},
-  year = {2022},
-  note = {https://ftextra.atusy.net},
-}
+
@Manual{R-ftExtra,
+  title = {ftExtra: Extensions for Flextable},
+  author = {Atsushi Yasumoto},
+  year = {2022},
+  note = {https://ftextra.atusy.net},
+}

Second, specify it within the YAML front matter.

-
---
-bibliography: ftExtra.bib
----
+
---
+bibliography: ftExtra.bib
+---

Finally, cite the references within tables.

-data.frame(
-  Cite = c("@R-ftExtra", "[@R-ftExtra]", "[-@R-ftExtra]"),
+data.frame(
+  Cite = c("@R-ftExtra", "[@R-ftExtra]", "[-@R-ftExtra]"),
   stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
-  colformat_md() %>%
-  flextable::autofit(add_w = 0.2)
-
+

If citation style such as Vancouver requires citations be numbered sequentially and consistently with the body, manually offset the number for example by colformat_md(.cite_offset = 5).

+

If citation style such as Vancouver requires citations be numbered +sequentially and consistently with the body, manually offset the number +for example by colformat_md(.cite_offset = 5).

-
-

-Math

+
+

Math +

The rendering of math is also possible.

-data.frame(math = "$e^{i\\theta} = \\cos \\theta + i \\sin \\theta$",
-           stringsAsFactors = FALSE) %>%
-  as_flextable() %>%
-  colformat_md() %>%
-  flextable::autofit(add_w = 0.2)
-
+

Note that results can be insufficient. This feature relies on Pandoc’s HTML writer, which

+

Note that results can be insufficient. This feature relies on +Pandoc’s HTML writer, which

-

render TeX math as far as possible using Unicode characters
https://pandoc.org/MANUAL.html#math-rendering-in-html

+

render TeX math as far as possible using Unicode characters
https://pandoc.org/MANUAL.html#math-rendering-in-html

-
-

-Emoji

-

Pandoc’s markdown provides an extension, emoji. To use it with colformat_md(), specify md_extensions="+emoji".

+
+

Emoji +

+

Pandoc’s markdown provides an extension, emoji. To use +it with colformat_md(), specify +md_extensions="+emoji".

-data.frame(emoji = c(":+1:"), stringsAsFactors = FALSE) %>%
-  as_flextable() %>%
+data.frame(emoji = c(":+1:"), stringsAsFactors = FALSE) %>%
+  as_flextable() %>%
   colformat_md(md_extensions = "+emoji")
-
+
-
-

-Other input formats

-

colformat_md supports variety of formats. They can even be HTML despite the name of the function.

+
+

Other input formats +

+

colformat_md supports variety of formats. They can even +be HTML despite the name of the function.

-data.frame(
+data.frame(
   x = "H<sub>2</sub>O",
   stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
+) %>%
+  as_flextable() %>%
   colformat_md(.from = "html")
-
+

Note that multiple paragraphs are not supported if .from is not "markdown". Below is an example with commonmark.

+

Note that multiple paragraphs are not supported if .from +is not "markdown". Below is an example with commonmark.

-data.frame(
+data.frame(
   x = "foo\n\nbar",
   stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
+) %>%
+  as_flextable() %>%
   colformat_md(.from = "commonmark")
-
+
+
-

This vignette introduces nice and easy way to display grouped data frame created by dplyr::group_by.

+

This vignette introduces nice and easy way to display grouped data +frame created by dplyr::group_by.

+library(ftExtra) +library(dplyr)
-grouped_iris <- iris %>%
-  group_by(Species) %>%
-  slice(1, 2)
+grouped_iris <- iris %>%
+  group_by(Species) %>%
+  slice(1, 2)
 
-grouped_mtcars <- mtcars %>%
-  mutate(model = rownames(mtcars)) %>%
-  head %>%
-  select(model, cyl, mpg, disp, am) %>%
-  group_by(am, cyl)
-
-

-Groups as titles

-
-

-Single grouping columns

+grouped_mtcars <- mtcars %>% + mutate(model = rownames(mtcars)) %>% + head %>% + select(model, cyl, mpg, disp, am) %>% + group_by(am, cyl)
+
+

Groups as titles +

+
+

Single grouping columns +

-grouped_iris %>% as_flextable()
-
+
-grouped_iris %>% as_flextable(hide_grouplabel = TRUE)
-
+
-
-

-Multiple grouping columns

+
+

Multiple grouping columns +

-grouped_mtcars %>% as_flextable()
-
+
-
-

-Groups as merged columns

-

By specifying as_flextable(groups_to = 'merged'), grouping variables are merged vertically. In this case, the default theme is changed to flextable::theme_vanilla because the booktab theme is not intuitive.

-
-

-Single grouping variable

+
+

Groups as merged columns +

+

By specifying as_flextable(groups_to = 'merged'), +grouping variables are merged vertically. In this case, the default +theme is changed to flextable::theme_vanilla because the +booktab theme is not intuitive.

+
+

Single grouping variable +

-grouped_iris %>%
-  as_flextable(groups_to = "merged")
-
+
-
-

-Multiple grouping variables

+
+

Multiple grouping variables +

-grouped_mtcars %>%
-  as_flextable(groups_to = "merged") %>%
-  flextable::theme_vanilla()
-
+
-
-

-Position of grouping variables

-

Grouping variables are moved to left by default. If you want to keep their positions, specify group_pos = 'asis'.

+
+

Position of grouping variables +

+

Grouping variables are moved to left by default. If you want to keep +their positions, specify group_pos = 'asis'.

-grouped_mtcars %>%
-  as_flextable(groups_to = "merged", groups_pos = "asis") %>%
-  flextable::theme_vanilla()
-
+
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Articles • ftExtra - + + - - - -
-
- -
- -
+
+
Format columns as markdown
+
+
Group rows
+
+
Create multi level headers
+
+
-
- +
- - + + diff --git a/docs/articles/transform-headers.html b/docs/articles/transform-headers.html index ae068c1..78d14f7 100644 --- a/docs/articles/transform-headers.html +++ b/docs/articles/transform-headers.html @@ -19,6 +19,8 @@ + +
+
@@ -101,14 +97,14 @@

Create multi level headers

This vignette introduces how to create multi level headers.

-
-

-Prepare flextable

+library(ftExtra)
+
+

Prepare flextable +

-ft <- iris[1:2, ] %>% as_flextable
+ft <- iris[1:2, ] %>% as_flextable
 ft
-
+
-
-

-Separate headers

-

The separate_header() function generates multi-level headers by separating original headers (row names) by delimiters.

+
+

Separate headers +

+

The separate_header() function generates multi-level +headers by separating original headers (row names) by delimiters.

-ft %>% separate_header()
-
+

The sep argument defines delimiters by regular expression. The default delimiters are . and _. Let’s see what happens when seop = "e"

+

The sep argument defines delimiters by regular +expression. The default delimiters are . and +_. Let’s see what happens when seop = "e"

-ft %>% separate_header(sep = "e")
-
+
-
-

-Span headers

-

The span_header() function also generates multi-level headers. Unlike the separate_header() function, the span_header() function merges adjacent headers if they have same values.

+
+

Span headers +

+

The span_header() function also generates multi-level +headers. Unlike the separate_header() function, the +span_header() function merges adjacent headers if they have +same values.

-ft %>% span_header()
-
+
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Authors and Citation • ftExtra - + + - - - - -
-
-
- -
+
- @@ -152,22 +102,21 @@

Authors

-
- +
- - + + diff --git a/docs/index.html b/docs/index.html index 068cc04..6f68344 100644 --- a/docs/index.html +++ b/docs/index.html @@ -21,6 +21,8 @@ + +
-
- +
+ -

The ftExtra package provides helper functions for the flextable package:

+

The ftExtra package provides helper functions for the flextable +package:

  • colformat_md parses markdown texts in columns
  • @@ -102,61 +99,61 @@ span_header makes multi-level headers
  • and more!
-
-

-Installation

-
-

-from CRAN

+
+

Installation +

+
+

from CRAN +

-install.packages("ftExtra")
+install.packages("ftExtra")
-
-

-from GitHub

+
+

from GitHub +

-options(repos = c(atusy = 'https://atusy.r-universe.dev', getOption("repos")))
-install.packages("ftExtra")
+options(repos = c(atusy = 'https://atusy.r-universe.dev', getOption("repos"))) +install.packages("ftExtra")
-
-

-Example

+
+

Example +

-
-

-Parse markdown texts

+library(ftExtra)
+
+

Parse markdown texts +

-data.frame(
-  x = c("**bold**", "*italic*"),
-  y = c("^superscript^", "~subscript~"),
-  z = c("***~ft~^Extra^** is*", "*Cool*"),
+data.frame(
+  x = c("**bold**", "*italic*"),
+  y = c("^superscript^", "~subscript~"),
+  z = c("***~ft~^Extra^** is*", "*Cool*"),
   stringsAsFactors = FALSE
-) %>%
-  as_flextable() %>%
+) %>%
+  as_flextable() %>%
   colformat_md()

-
-

-Span headers

+
+

Span headers +

-iris %>%
-  head %>%
-  as_flextable() %>%
+iris %>%
+  head %>%
+  as_flextable() %>%
   span_header()

-
-

-Group rows

+
+

Group rows +

-library(dplyr, warn.conflicts = FALSE)
-iris %>%
-  group_by(Species) %>%
-  slice(1:2) %>%
-  as_flextable()
+library(dplyr, warn.conflicts = FALSE) +iris %>% + group_by(Species) %>% + slice(1:2) %>% + as_flextable()

@@ -165,50 +162,60 @@

- - + + diff --git a/docs/reference/as_paragraph_md.html b/docs/reference/as_paragraph_md.html index 1d75c89..d191cf1 100644 --- a/docs/reference/as_paragraph_md.html +++ b/docs/reference/as_paragraph_md.html @@ -1,67 +1,12 @@ - - - - - - - -Convert a character vector into markdown paragraph(s) — as_paragraph_md • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Convert a character vector into markdown paragraph(s) — as_paragraph_md • ftExtra - - + + - - -
-
- -
- -
+
@@ -138,100 +68,84 @@

Convert a character vector into markdown paragraph(s)

Parse markdown cells and returns the "paragraph" object.

-
as_paragraph_md(
-  x,
-  auto_color_link = "blue",
-  md_extensions = NULL,
-  pandoc_args = NULL,
-  replace_na = "",
-  .from = "markdown+autolink_bare_uris",
-  .footnote_options = NULL,
-  ...
-)
- -

Arguments

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
x

A character vector.

auto_color_link

A color of the link texts.

md_extensions

Pandoc's extensions. Although it is prefixed with "md", extensions for any +

+
as_paragraph_md(
+  x,
+  auto_color_link = "blue",
+  md_extensions = NULL,
+  pandoc_args = NULL,
+  replace_na = "",
+  .from = "markdown+autolink_bare_uris",
+  .footnote_options = NULL,
+  ...
+)
+
+ +
+

Arguments

+
x
+

A character vector.

+
auto_color_link
+

A color of the link texts.

+
md_extensions
+

Pandoc's extensions. Although it is prefixed with "md", extensions for any formats specified to .from can be used. See -https://www.pandoc.org/MANUAL.html#extensions for details.

pandoc_args

Additional command line options to pass to pandoc

replace_na

A value to replace NA (default = "").

.from

Pandoc's --from argument (default: 'markdown+autolink_bare_uris').

.footnote_options

Options for footnotes generated by footnote_options().

...

Arguments passed to internal functions.

- - -

Examples

-
if (rmarkdown::pandoc_available("2.0.6")) { - library(flextable) - ft <- flextable( - data.frame( - x = c("**foo** bar", "***baz***", "*qux*"), - stringsAsFactors = FALSE - ) - ) - ft <- compose(ft, j = "x", i = 1:2, value = as_paragraph_md(x)) - autofit(ft) -} -
#> a flextable object. -#> col_keys: `x` -#> header has 1 row(s) -#> body has 3 row(s) -#> original dataset sample: -#> [1] "**foo** bar" "***baz***" "*qux*"
+https://www.pandoc.org/MANUAL.html#extensions for details.

+
pandoc_args
+

Additional command line options to pass to pandoc

+
replace_na
+

A value to replace NA (default = "").

+
.from
+

Pandoc's --from argument (default: 'markdown+autolink_bare_uris').

+
.footnote_options
+

Options for footnotes generated by footnote_options().

+
...
+

Arguments passed to internal functions.

+
+ +
+

Examples

+
if (rmarkdown::pandoc_available("2.0.6")) {
+  library(flextable)
+  ft <- flextable(
+    data.frame(
+      x = c("**foo** bar", "***baz***", "*qux*"),
+      stringsAsFactors = FALSE
+    )
+  )
+  ft <- compose(ft, j = "x", i = 1:2, value = as_paragraph_md(x))
+  autofit(ft)
+}
+#> a flextable object.
+#> col_keys: `x` 
+#> header has 1 row(s) 
+#> body has 3 row(s) 
+#> original dataset sample: 
+#> [1] "**foo** bar" "***baz***"   "*qux*"      
+
+
+

-
- +
- - + + diff --git a/docs/reference/colformat_md.html b/docs/reference/colformat_md.html index c87c48a..21f8223 100644 --- a/docs/reference/colformat_md.html +++ b/docs/reference/colformat_md.html @@ -1,67 +1,12 @@ - - - - - - - -Format character columns as markdown text — colformat_md • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Format character columns as markdown text — colformat_md • ftExtra - - + + - - -
-
- -
- -
+
@@ -138,111 +68,91 @@

Format character columns as markdown text

Format character columns as markdown text

-
colformat_md(
-  x,
-  j = where(is.character),
-  part = c("body", "header", "all"),
-  auto_color_link = "blue",
-  md_extensions = NULL,
-  pandoc_args = NULL,
-  replace_na = "",
-  .from = "markdown+autolink_bare_uris",
-  .footnote_options = footnote_options(),
-  .sep = "\n\n"
-)
- -

Arguments

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
x

A flextable object

j

Columns to be treated as markdown texts. -Selection can be done by the semantics of dplyr::select().

part

One of "body", "header", and "all". If "all", formatting proceeds in the -order of "header" and "body".

auto_color_link

A color of the link texts.

md_extensions

Pandoc's extensions. Although it is prefixed with "md", extensions for any +

+
colformat_md(
+  x,
+  j = where(is.character),
+  part = c("body", "header", "all"),
+  auto_color_link = "blue",
+  md_extensions = NULL,
+  pandoc_args = NULL,
+  replace_na = "",
+  .from = "markdown+autolink_bare_uris",
+  .footnote_options = footnote_options(),
+  .sep = "\n\n"
+)
+
+ +
+

Arguments

+
x
+

A flextable object

+
j
+

Columns to be treated as markdown texts. +Selection can be done by the semantics of dplyr::select().

+
part
+

One of "body", "header", and "all". If "all", formatting proceeds in the +order of "header" and "body".

+
auto_color_link
+

A color of the link texts.

+
md_extensions
+

Pandoc's extensions. Although it is prefixed with "md", extensions for any formats specified to .from can be used. See -https://www.pandoc.org/MANUAL.html#extensions for details.

pandoc_args

Additional command line options to pass to pandoc

replace_na

A value to replace NA (default = "").

.from

Pandoc's --from argument (default: 'markdown+autolink_bare_uris').

.footnote_options

Options for footnotes generated by footnote_options().

.sep

A separator of paragraphs (default: "\n\n")

- - -

Examples

-
if (rmarkdown::pandoc_available("2.0.6")) { - d <- data.frame( - x = c("**bold**", "*italic*"), - y = c("^superscript^", "~subscript~"), - z = c("***^ft^~Extra~** is*", "*Cool*") - ) - colformat_md(flextable::flextable(d)) -} -
#> a flextable object. -#> col_keys: `x`, `y`, `z` -#> header has 1 row(s) -#> body has 2 row(s) -#> original dataset sample: -#> x y z -#> 1 **bold** ^superscript^ ***^ft^~Extra~** is* -#> 2 *italic* ~subscript~ *Cool*
+https://www.pandoc.org/MANUAL.html#extensions for details.

+
pandoc_args
+

Additional command line options to pass to pandoc

+
replace_na
+

A value to replace NA (default = "").

+
.from
+

Pandoc's --from argument (default: 'markdown+autolink_bare_uris').

+
.footnote_options
+

Options for footnotes generated by footnote_options().

+
.sep
+

A separator of paragraphs (default: "\n\n")

+
+ +
+

Examples

+
if (rmarkdown::pandoc_available("2.0.6")) {
+  d <- data.frame(
+    x = c("**bold**", "*italic*"),
+    y = c("^superscript^", "~subscript~"),
+    z = c("***^ft^~Extra~** is*", "*Cool*")
+  )
+  colformat_md(flextable::flextable(d))
+}
+#> a flextable object.
+#> col_keys: `x`, `y`, `z` 
+#> header has 1 row(s) 
+#> body has 2 row(s) 
+#> original dataset sample: 
+#>          x             y                    z
+#> 1 **bold** ^superscript^ ***^ft^~Extra~** is*
+#> 2 *italic*   ~subscript~               *Cool*
+
+
+
-
- +
- - + + diff --git a/docs/reference/footnote_options.html b/docs/reference/footnote_options.html index 07a243a..6246e64 100644 --- a/docs/reference/footnote_options.html +++ b/docs/reference/footnote_options.html @@ -1,67 +1,12 @@ - - - - - - - -Options for footnotes — footnote_options • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Options for footnotes — footnote_options • ftExtra - - + + - - -
-
- -
- -
+
@@ -138,79 +68,67 @@

Options for footnotes

Configure options for footnotes.

-
footnote_options(
-  ref = c("1", "a", "A", "i", "I", "*"),
-  prefix = "",
-  suffix = "",
-  start = 1L,
-  max = 26L,
-  inline = FALSE,
-  sep = "; "
-)
- -

Arguments

- - - - - - - - - - - - - - - - - - - - - - - - - - -
ref

One of "1", "a", "A", "i", "I", or "*" to as a choice for a symbol to -cross-reference footnotes.

prefix, suffix

Pre- and suf-fixes for ref (default: "").

start

A starting number of footnotes.

max

A max number of footnotes.

inline

whether to add footnote on same line as previous footnote or not

sep

inline = T, character string to use as a separator between footnotes

- -

Value

+
+
footnote_options(
+  ref = c("1", "a", "A", "i", "I", "*"),
+  prefix = "",
+  suffix = "",
+  start = 1L,
+  max = 26L,
+  inline = FALSE,
+  sep = "; "
+)
+
+
+

Arguments

+
ref
+

One of "1", "a", "A", "i", "I", or "*" to as a choice for a symbol to +cross-reference footnotes.

+
prefix, suffix
+

Pre- and suf-fixes for ref (default: "").

+
start
+

A starting number of footnotes.

+
max
+

A max number of footnotes.

+
inline
+

whether to add footnote on same line as previous footnote or not

+
sep
+

inline = T, character string to use as a separator between footnotes

+
+
+

Value

An environment

+
-

Examples

-
o <- footnote_options("1", start = 1L) - -
+
+

Examples

+
o <- footnote_options("1", start = 1L)
+
+
+
+
-
- +
- - + + diff --git a/docs/reference/index.html b/docs/reference/index.html index dd86f8f..1710f33 100644 --- a/docs/reference/index.html +++ b/docs/reference/index.html @@ -1,66 +1,12 @@ - - - - - - - -Function reference • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Function reference • ftExtra + + - - - - -
-
- -
- -
+
- - - - - - - - - - -
-

All functions

+ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+

All functions

+

as_flextable(<grouped_df>) as_flextable(<data.frame>)

method to convert object to flextable

+

as_paragraph_md()

Convert a character vector into markdown paragraph(s)

+

colformat_md()

Format character columns as markdown text

+

footnote_options()

Options for footnotes

+

separate_header()

Separate the header based on delimiters

+

span_header()

Span the header based on delimiters

+

with_blanks()

Specify blank columns easily via col_keys

- +
+
-
- +
- - + + diff --git a/docs/reference/reexports.html b/docs/reference/reexports.html index f3172b2..845906b 100644 --- a/docs/reference/reexports.html +++ b/docs/reference/reexports.html @@ -1,74 +1,23 @@ - - - - - - - -Objects exported from other packages — reexports • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Objects exported from other packages — reexports • ftExtra + flextable +as_flextable + magrittr +%&gt;% - - - - - - - - - + + -
-
- -
- -
+

These objects are imported from other packages. Follow the links below to see their documentation.

-
-
flextable

as_flextable

+
flextable
+

as_flextable

-
magrittr

%>%

-
-
+
magrittr
+

%>%

+ +
+
-
- +
- - + + diff --git a/docs/reference/separate_header.html b/docs/reference/separate_header.html index d490dfa..00b7c4d 100644 --- a/docs/reference/separate_header.html +++ b/docs/reference/separate_header.html @@ -1,67 +1,12 @@ - - - - - - - -Separate the header based on delimiters — separate_header • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Separate the header based on delimiters — separate_header • ftExtra - - + + - - -
-
- -
- -
+
@@ -138,82 +68,74 @@

Separate the header based on delimiters

Separate the header based on delimiters

-
separate_header(
-  x,
-  sep = "[_\\.]",
-  theme_fun = flextable::theme_booktabs,
-  ...
-)
- -

Arguments

- - - - - - - - - - - - - - - - - - -
x

A flextable object`

sep

Separator between columns.

+
+
separate_header(
+  x,
+  sep = "[_\\.]",
+  theme_fun = flextable::theme_booktabs,
+  ...
+)
+
+ +
+

Arguments

+
x
+

A flextable object`

+
sep
+

Separator between columns.

If character, sep is interpreted as a regular expression. The default value is a regular expression that matches any sequence of non-alphanumeric values.

If numeric, sep is interpreted as character positions to split at. Positive values start at 1 at the far-left of the string; negative value start at -1 at the far-right of the string. The length of sep should be one less than -into.

theme_fun

deprecated, use set_flextable_defaults() instead.

...

Passed to theme_fun

- - -

Examples

-
iris %>% - as_flextable() %>% - separate_header() -
#> a flextable object. -#> col_keys: `Sepal.Length`, `Sepal.Width`, `Petal.Length`, `Petal.Width`, `Species` -#> header has 2 row(s) -#> body has 150 row(s) -#> original dataset sample: -#> Sepal.Length Sepal.Width Petal.Length Petal.Width Species -#> 1 5.1 3.5 1.4 0.2 setosa -#> 2 4.9 3.0 1.4 0.2 setosa -#> 3 4.7 3.2 1.3 0.2 setosa -#> 4 4.6 3.1 1.5 0.2 setosa -#> 5 5.0 3.6 1.4 0.2 setosa
+into.

+
theme_fun
+

deprecated, use set_flextable_defaults() instead.

+
...
+

Passed to theme_fun

+
+ +
+

Examples

+
iris %>%
+  as_flextable() %>%
+  separate_header()
+#> a flextable object.
+#> col_keys: `Sepal.Length`, `Sepal.Width`, `Petal.Length`, `Petal.Width`, `Species` 
+#> header has 2 row(s) 
+#> body has 150 row(s) 
+#> original dataset sample: 
+#>   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
+#> 1          5.1         3.5          1.4         0.2  setosa
+#> 2          4.9         3.0          1.4         0.2  setosa
+#> 3          4.7         3.2          1.3         0.2  setosa
+#> 4          4.6         3.1          1.5         0.2  setosa
+#> 5          5.0         3.6          1.4         0.2  setosa
+
+
+
-
- +
- - + + diff --git a/docs/reference/span_header.html b/docs/reference/span_header.html index 20dcad6..6d4e5eb 100644 --- a/docs/reference/span_header.html +++ b/docs/reference/span_header.html @@ -1,67 +1,12 @@ - - - - - - - -Span the header based on delimiters — span_header • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Span the header based on delimiters — span_header • ftExtra - - + + - - -
-
- -
- -
+
@@ -138,77 +68,69 @@

Span the header based on delimiters

Span the header based on delimiters

-
span_header(x, sep = "[_\\.]", theme_fun = flextable::theme_booktabs, ...)
- -

Arguments

- - - - - - - - - - - - - - - - - - -
x

A flextable object`

sep

Separator between columns.

+
+
span_header(x, sep = "[_\\.]", theme_fun = flextable::theme_booktabs, ...)
+
+ +
+

Arguments

+
x
+

A flextable object`

+
sep
+

Separator between columns.

If character, sep is interpreted as a regular expression. The default value is a regular expression that matches any sequence of non-alphanumeric values.

If numeric, sep is interpreted as character positions to split at. Positive values start at 1 at the far-left of the string; negative value start at -1 at the far-right of the string. The length of sep should be one less than -into.

theme_fun

deprecated, use set_flextable_defaults() instead.

...

Passed to theme_fun

- - -

Examples

-
iris %>% - as_flextable() %>% - span_header() -
#> a flextable object. -#> col_keys: `Sepal.Length`, `Sepal.Width`, `Petal.Length`, `Petal.Width`, `Species` -#> header has 2 row(s) -#> body has 150 row(s) -#> original dataset sample: -#> Sepal.Length Sepal.Width Petal.Length Petal.Width Species -#> 1 5.1 3.5 1.4 0.2 setosa -#> 2 4.9 3.0 1.4 0.2 setosa -#> 3 4.7 3.2 1.3 0.2 setosa -#> 4 4.6 3.1 1.5 0.2 setosa -#> 5 5.0 3.6 1.4 0.2 setosa
+into.

+
theme_fun
+

deprecated, use set_flextable_defaults() instead.

+
...
+

Passed to theme_fun

+
+ +
+

Examples

+
iris %>%
+  as_flextable() %>%
+  span_header()
+#> a flextable object.
+#> col_keys: `Sepal.Length`, `Sepal.Width`, `Petal.Length`, `Petal.Width`, `Species` 
+#> header has 2 row(s) 
+#> body has 150 row(s) 
+#> original dataset sample: 
+#>   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
+#> 1          5.1         3.5          1.4         0.2  setosa
+#> 2          4.9         3.0          1.4         0.2  setosa
+#> 3          4.7         3.2          1.3         0.2  setosa
+#> 4          4.6         3.1          1.5         0.2  setosa
+#> 5          5.0         3.6          1.4         0.2  setosa
+
+
+
-
- +
- - + + diff --git a/docs/reference/with_blanks.html b/docs/reference/with_blanks.html index af9338b..cee4d83 100644 --- a/docs/reference/with_blanks.html +++ b/docs/reference/with_blanks.html @@ -1,67 +1,12 @@ - - - - - - - -Specify blank columns easily via col_keys — with_blanks • ftExtra - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Specify blank columns easily via col_keys — with_blanks • ftExtra - - + + - - -
-
- -
- -
+
@@ -138,58 +68,56 @@

Specify blank columns easily via col_keys

Specify blank columns easily via col_keys

-
with_blanks(after = NULL, before = NULL)
- -

Arguments

- - - - - - -
after, before

Blank columns are added after/before the selected columns. -Selections can be done by the semantics of dplyr::select.

- - -

Examples

-
iris %>% - as_flextable(col_keys = with_blanks(dplyr::ends_with("Width"))) -
#> a flextable object. -#> col_keys: `Sepal.Length`, `Sepal.Width`, `..after1`, `Petal.Length`, `Petal.Width`, `..after2`, `Species` -#> header has 1 row(s) -#> body has 150 row(s) -#> original dataset sample: -#> Sepal.Length Sepal.Width Petal.Length Petal.Width Species ..after1 ..after2 -#> 1 5.1 3.5 1.4 0.2 setosa -#> 2 4.9 3.0 1.4 0.2 setosa -#> 3 4.7 3.2 1.3 0.2 setosa -#> 4 4.6 3.1 1.5 0.2 setosa -#> 5 5.0 3.6 1.4 0.2 setosa
+
+
with_blanks(after = NULL, before = NULL)
+
+ +
+

Arguments

+
after, before
+

Blank columns are added after/before the selected columns. +Selections can be done by the semantics of dplyr::select.

+
+ +
+

Examples

+
iris %>%
+  as_flextable(col_keys = with_blanks(dplyr::ends_with("Width")))
+#> a flextable object.
+#> col_keys: `Sepal.Length`, `Sepal.Width`, `..after1`, `Petal.Length`, `Petal.Width`, `..after2`, `Species` 
+#> header has 1 row(s) 
+#> body has 150 row(s) 
+#> original dataset sample: 
+#>   Sepal.Length Sepal.Width Petal.Length Petal.Width Species ..after1 ..after2
+#> 1          5.1         3.5          1.4         0.2  setosa                  
+#> 2          4.9         3.0          1.4         0.2  setosa                  
+#> 3          4.7         3.2          1.3         0.2  setosa                  
+#> 4          4.6         3.1          1.5         0.2  setosa                  
+#> 5          5.0         3.6          1.4         0.2  setosa                  
+
+
+
-
- +
- - + + diff --git a/man/as_flextable_methods.Rd b/man/as_flextable_methods.Rd index 4b0ba4e..13ad09c 100644 --- a/man/as_flextable_methods.Rd +++ b/man/as_flextable_methods.Rd @@ -58,5 +58,6 @@ Other as_flextable methods: \code{\link[flextable]{as_flextable.grouped_data}()}, \code{\link[flextable]{as_flextable.htest}()}, \code{\link[flextable]{as_flextable.lm}()}, +\code{\link[flextable]{as_flextable.tabulator}()}, \code{\link[flextable]{as_flextable.xtable}()} }