我收到了一位评论者的评论,他希望在人口特征表(表 1)中包含每行特定变量级别的所有 p 值。尽管这个要求对我来说似乎很奇怪(而且不准确),但我还是同意他的建议。
library(tableone)
## Load data
library(survival); data(pbc)
# drop ID from variable list
vars <- names(pbc)[-1]
## Create Table 1 stratified by trt (can add more stratifying variables)
tableOne <- CreateTableOne(vars = vars, strata = c("trt"), data = pbc, factorVars = c("status","edema","stage"))
print(tableOne, nonnormal = c("bili","chol","copper","alk.phos","trig"), exact = c("status","stage"), smd = TRUE)
我需要有变量的每个级别的 p 值和status
,并进行 Bonferroni 校正。我浏览了文档但没有成功。此外,使用卡方比较跨行的样本大小是否正确?edema
stage
更新:
我不确定我的方法是否正确,但是我想与您分享。我为变量生成了status
每个层的虚拟变量,而不是计算chisq
.
library(tableone)
## Load data
library(survival); data(pbc)
d <- pbc[,c("status", "trt")]
# Convert dummy variables
d$status.0 <- ifelse(d$status==0, 1,0)
d$status.1 <- ifelse(d$status==1, 1,0)
d$status.2 <- ifelse(d$status==2, 1,0)
t <- rbind(
chisq.test(d$status.0, d$trt),
# p-value = 0.7202
chisq.test(d$status.1, d$trt),
# p-value = 1
chisq.test(d$status.2, d$trt)
#p-value = 0.7818
)
t
用于多重比较的 BONFERRONI ADJ:
p <- t[,"p.value"]
p.adjust(p, method = "bonferroni")