[英]How do I fix this "Error in .subset2(x, i, exact = exact)" problem in R?
我在 R 中使用以下數據框:
ID <- c(LETTERS[1:10])
GLUC <- c(88,NA,110,NA,90,88,120,110,NA,90)
TGL <- c(NA,150,NA,200,210,NA,164,170,190,NA)
HDL <- c(32,60,NA,65,NA,32,NA,70,NA,75)
LDL <- c(99,NA,120,165,150,210,NA,188,190,NA)
patient_num <- data.frame(ID,GLUC,TGL,HDL,LDL)
我想創建一個矩陣,其中 GLUC、TGL、HDL 和 LDL 作為行名稱,平均值、中值、sd、n 和 n_miss 作為列名稱。 當我輸入以下代碼時:
r <- c(mean(patient_num[[varname]],na.rm=TRUE),
median(patient_num[[varname]],na.rm=TRUE),
sd(patient_num[[varname]],na.rm=TRUE),
sum(!is.na(patient_num[[varname]])),
sum(is.na(patient_num[[varname]]))
)
if (length(varname) == 1){
r <- matrix(r,nrow=T)
} else{
for (index in 2:length(varname)){
oneRow = table1(patient_num,varname[[index]])
r <- rbind(r,oneRow)
}
}
rownames(r) <- varname
colnames(r) <- c("mean","median","sd","n","n_miss")
return(r)
}
table1(patient_num,c("GLUC","TGL","HDL","LDL"))
我收到一條錯誤消息:
.subset2(x, i,exact =exact) 中的錯誤:遞歸索引在級別 2 失敗
似乎無法弄清楚出了什么問題
使用base R
sapply()
有一個更簡單的解決方案:
new_df <- sapply(patient_num, function(x) list(
mean = mean(x, na.rm = T),
sd = sd(x, na.rm = T),
n = sum(!is.na(x)),
is_na = sum(is.na(x))))
t(new_df)
#> mean sd n is_na
#>ID NA NA 10 0
#>GLUC 99.42857 13.45185 7 3
#>TGL 180.6667 23.0362 6 4
#>HDL 55.66667 19.00175 6 4
#>LDL 160.2857 40.06126 7 3
如果您只想要每行中非 NA 條目的計數,您只需從patient_num
刪除ID
並運行相同的代碼。
請注意,您可能希望將new_df
轉換回data.frame
。
您一次只能使用[[
選擇一列。
這是使用dplyr
函數的另一種方法。
library(dplyr)
table1 <- function(data, varname) {
data %>%
select(all_of(varname)) %>%
tidyr::pivot_longer(cols = everything()) %>%
group_by(name) %>%
summarise(mean = mean(value, na.rm = TRUE),
median = median(value, na.rm = TRUE),
sd = sd(value, na.rm = TRUE),
n = sum(!is.na(value)),
n_miss = sum(is.na(value)))
}
table1(patient_num,c("GLUC","TGL","HDL","LDL"))
# A tibble: 4 x 6
# name mean median sd n n_miss
# <chr> <dbl> <dbl> <dbl> <int> <int>
#1 GLUC 99.4 90 13.5 7 3
#2 HDL 55.7 62.5 19.0 6 4
#3 LDL 160. 165 40.1 7 3
#4 TGL 181. 180 23.0 6 4
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.