簡體   English   中英

R 中的 cox 回歸輸出表或圖

[英]cox regression output table or plot in R

我有一個使用strata()tt()的 Cox 回歸。

是否有任何軟件包可以幫助以表格格式生成美觀、信息豐富的結果輸出? 雖然ggforest()處理tt()它不處理ggforest() strata()

除了打印summary(coxph)之外,我正在尋找任何方法來產生合適的輸出。 無論是 Latex 還是 HTML。

到目前為止唯一的解決方案是自己構建表格,但這看起來並沒有足夠吸引人,無法放入論文中......

這是虛擬數據集:

set.seed(132456)
'dummy survival data'
df<-data.frame(id=seq(1,1000,1), event=rep(0,1000),time=floor(runif(1000,7,10)),group=floor(runif(1000,0,2)), 
               var1 = rnorm(1000, 1, 3), var2 = seq(1,1000))
'set events for a few random subjects'

id_list<-c(as.numeric(floor(runif(500,1,1000))))
df$event[df$id %in% id_list]<-1

'set survival times for events'
t_list<-c(as.numeric(floor(runif(394,1,5))))
df2<-df[df$event==1,]
df2$time<-t_list


'combine data'
df<-rbind(df,df2)
summary(df)

'Set up surfit '
require(survminer)
KM_fit<-coxph(Surv(time , event) ~ tt(var2) + strata(group)+ var1 ,data= df)

ggforest()返回以下錯誤:

> ggforest(KM_fit)
Error in `[.data.frame`(data, , var) : undefined columns selected
additional warning:
In .get_data(model, data = data) :
  The `data` argument is not provided. Data will be extracted from model fit.

如果ggforest() strataggforest()函數會起作用。 但是我處理的模型使用它......所以沒有解決方案。

下面返回一個非常基本的表,如果我對布局有更多的了解可以使用它,但它真的不漂亮!

# Prepare the columns
beta <- coef(KM_fit)
se   <- sqrt(diag(KM_fit$var))
p    <- 1 - pchisq((beta/se)^2, 1)
CI <- round(exp(confint(KM_fit)), 2)

# Bind columns together, and select desired rows
res <- cbind(beta, se = exp(beta), CI, p)


# Print results in a LaTeX-ready form
knitr::kable(
xtable(res)
)

感謝任何提示和技巧!

謝謝一堆!

也試過finalfit()沒有成功....

以下是一些選項,具體取決於您想要包含在決賽桌中的內容。

coxph(Surv(time , event) ~ tt(var2) + strata(group)+ var1 ,data= df) %>% 
  finalfit::fit2df() %>% 
  knitr::kable()

coxph(Surv(time , event) ~ tt(var2) + strata(group)+ var1 ,data= df) %>% 
  finalfit::fit2df(condense = FALSE) %>% 
  knitr::kable()

coxph(Surv(time , event) ~ tt(var2) + strata(group)+ var1 ,data= df) %>% 
  broom::tidy(exp = TRUE)

編輯

digits參數用於壓縮輸出。 如果您將值輸出為數字,則在打印之前它們不會四舍五入。 所以這里有兩個選項。

> coxph(Surv(time , event) ~ tt(var2) + strata(group)+ var1 ,data= df) %>% 
+   finalfit::fit2df(digits = c(3,3,3)) %>% 
+   knitr::kable()


|explanatory |HR                           |
|:-----------|:----------------------------|
|tt(var2)    |0.998 (0.995-1.001, p=0.211) |
|var1        |1.006 (0.983-1.029, p=0.616) |
> 
> coxph(Surv(time , event) ~ tt(var2) + strata(group)+ var1 ,data= df) %>% 
+   finalfit::fit2df(condense = FALSE) %>% 
+   knitr::kable(digits = c(0, 2, 3, 4, 5))


|explanatory |   HR|   L95|    U95|       p|
|:-----------|----:|-----:|------:|-------:|
|tt(var2)    | 1.00| 0.995| 1.0010| 0.21097|
|var1        | 1.01| 0.983| 1.0294| 0.61612|
> 

在 Finalfit 中編輯 2標簽變量很容易。 問題是當前不支持tt()

df %>% 
  mutate(
    var1 = ff_label(var1, "Pretty var1"),
    var2 = ff_label(var2, "Also very pretty var2"),
    group = factor(group) %>% 
      ff_label("Group (strata)")
    ) %>% 
  finalfit("Surv(time, event)", c("var1", "var2", "strata(group)"), column = TRUE)

 Dependent: Surv(time, event)                     all          HR (univariable)        HR (multivariable)
                  Pretty var1 Mean (SD)     0.9 (3.1) 1.01 (0.98-1.03, p=0.636) 1.01 (0.98-1.03, p=0.646)
        Also very pretty var2 Mean (SD) 504.5 (288.3) 1.00 (1.00-1.00, p=0.479) 1.00 (1.00-1.00, p=0.484)
               Group (strata)         0    714 (51.2)                         -                         -
                                      1    680 (48.8)                         -                         -

如您所說,您可以手動編輯簡單的表格

coxph(Surv(time , event) ~ tt(var2) + strata(group)+ var1 ,data= df) %>% 
  finalfit::fit2df(condense = FALSE) %>%
  mutate(
    explanatory = c("Pretty var2 (time dependent)", "Also pretty var1")
  ) %>% 
  knitr::kable(digits = c(3,3,3,3,3))

|explanatory                  |    HR|   L95|   U95|     p|
|:----------------------------|-----:|-----:|-----:|-----:|
|Pretty var2 (time dependent) | 0.998| 0.995| 1.001| 0.211|
|Also pretty var1             | 1.006| 0.983| 1.029| 0.616|

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM