модели регрессии в r вывод из таблицы в слово
Я использовал sjplot для создания комбинированной таблицы. Это создает таблицу HTML. Я хотел бы сделать таблицу, которую можно было бы экспортировать в word.
Я просмотрел этот пост, в котором обсуждается копирование и вставка в слово, но это меняет форматирование столбцов и строк. Вывести несколько таблиц регрессии на несколько страниц документа Word в R
n1 <- glm(N ~ Age_2 , data = n_data, family = "binomial")
g1 <- glm(G ~ Age_2 , data = g1_data, family = "binomial")
ga1 <- glm(G_1 ~ Age_2 , data = ga1_data, family = "binomial")
l1 <- glm(L_1 ~ Age_2 , data = l1_data, family = "binomial")
c1 <- glm(C_1 ~ Age_2 , data = c1_data, family = "binomial")
m1 <- glm(m ~ Age_2 , data = m1_data, family = "binomial")
tab_model (n1,g1,ga1,l1,c1,m1)
Также можно ли добавить строку с числом, имеющим результат (например, число N), в дополнение к общему количеству наблюдений на группу?
Какие-либо предложения? Готовы попробовать другие пакеты.
2 ответа
Мы можем сделать это с помощью пакета gtsummary. По умолчанию gtsummary печатает таблицы с пакетами gt, которые не поддерживают вывод Word. Но мы можем преобразовать любой объект gtsummary в тип, поддерживаемый Word. В приведенном ниже примере мы преобразуем его в файл с расширением.
Я предоставил 2 формата для вашего решения: одна длинная таблица и одна (очень) широкая таблица. Вот как выглядит длинный стол:
Широкий формат выглядит так:
Мы получаем количество событий для каждой модели, используя add_nevent()
функция. Вот полный код файла R Markdown. Обратите вниманиеas_flextable()
является новым, и вам необходимо установить версию gtsummary для разработчиков remotes::install_github("ddsjoberg/gtsummary")
http://www.danieldsjoberg.com/gtsummary/index.html
---
title: "Regression Tables with gtsummary"
output: word_document
---
```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE)
```
## Data
```{r}
set.seed(324524)
logistic_s <- data.frame(N=rbinom(200,1,0.5),
G=rbinom(200,1,0.5),
G_1=rbinom(200,1,0.5),
L_1=rbinom(200,1,0.5),
C_1=rbinom(200,1,0.5),
m=rbinom(200,1,0.5),
Age_2=round(rnorm(200,40,6)))
```
## Long Table
Create a table that is one line per model
```{r}
library(gtsummary)
library(tidyverse)
# build models
tbl_uvregression(
data = logistic_s,
x = Age_2,
method = glm,
method.args = list(family = binomial),
exponentiate = TRUE
) %>%
modify_header(label = "**Model Outcome**") %>%
# add the number of evenets
add_nevent() %>%
# export as flextable instead of gt table
as_flextable()
```
## Wide Table
Create a table that wide
```{r cars}
# list all outcomes
outcomes <- c("N", "G", "G_1", "L_1", "C_1", "m")
# map over each outcome to make a model and table
list_regression_tables <-
map(outcomes,
# make a model for each outcome
~glm(
formula = as.formula(paste(.x, "Age_2", sep = "~")),
data = logistic_s,
family = binomial
) %>%
# putting model in table with tbl_regression
tbl_regression(exponentiate = TRUE) %>%
# add the number of evenets
add_nevent()
)
# merging all tables together
tbl_merge(tbls = list_regression_tables,
tab_spanner = outcomes) %>%
# export as flextable instead of gt table
as_flextable()
```
Удачного кодирования!
Поскольку sjPlot
выводит в html, очень сложно напрямую поместить его в документ Word. Вот пример того, как сделать что-то похожее на то, что вы хотите сделать, используяknitr
, rmarkdown
, jtools
, а также huxtable
. Я использую RStudio с документом rmarkdown, который я связываю с документом Word.
---
title: "jtools to Output Logistic Regression Models"
author: "sar"
date: "`r format(Sys.time(), '%d %B %Y')`"
output: word_document
---
```{r setup, include=FALSE}
library(knitr)
library(jtools)
library(huxtable)
knitr::opts_chunk$set(echo=FALSE, warning = FALSE)
```
# Introduction
This is a test document to demonstrate how knitr and rmarkdown can be used to put output from jtools
into a Word Document
```{r OutputTable}
set.seed(1234)
logistic_s <- data.frame(N=rbinom(200,1,0.5),
G=rbinom(200,1,0.5),
G_1=rbinom(200,1,0.5),
L_1=rbinom(200,1,0.5),
C_1=rbinom(200,1,0.5),
m=rbinom(200,1,0.5),
Age_2=round(rnorm(200,40,6)))
n1 <- glm(N ~ Age_2 , data = logistic_s, family = "binomial")
g1 <- glm(G ~ Age_2 , data = logistic_s, family = "binomial")
ga1 <- glm(G_1 ~ Age_2 , data = logistic_s, family = "binomial")
l1 <- glm(L_1 ~ Age_2 , data = logistic_s, family = "binomial")
c1 <- glm(C_1 ~ Age_2 , data = logistic_s, family = "binomial")
m1 <- glm(m ~ Age_2 , data = logistic_s, family = "binomial")
model_summs <- export_summs(n1,g1,ga1,l1,c1,m1,
error_format = "({conf.low}, {conf.high})",
model.names = c("N","G","G_1","L_1","C_1","m"))
col_width(model_summs) = c(0.84,rep(0.95,6))
model_summs
```