在 R 函数中打印列的文字名称?
Printing the literal name of a column inside an R function?
我对 R 比较陌生,正在尝试创建一个函数来应用于我想为其生成频率表的变量名列表。但是,我编写的函数打印函数的局部变量名称,而不是变量的实际名称。
create_tabyls <- function(df,col_name) {
result <- tabyl(df[[col_name]]) %>%
adorn_pct_formatting() %>%
adorn_totals()
print(result)
}
然后当我调用我的函数时:
create_tabyls(df,'AGE')
我得到:
df[[col_name]] n percent valid_percent
1 43141 3.5% 3.7%
2 810172 66.4% 69.7%
3 309058 25.3% 26.6%
<NA> 57246 4.7% -
Total 1219617 - -
我不明白为什么我的输出打印为 df[[col_name]] 而不是 df[[AGE]]。谁能帮我弄清楚我犯了什么错误?我试图让它打印我给函数的实际值,而不是仅仅打印函数变量的名称。
感谢您的帮助!
我们可以转换为 sym
bol 并计算 (!!
),因为输入是一个字符串
library(janitor)
library(dplyr)
create_tabyls <- function(df,col_name) {
df %>%
select(col_name) %>%
tabyl(!! rlang::sym(col_name)) %>%
adorn_pct_formatting() %>%
adorn_totals()
}
-测试
data(mtcars)
mtcars$vs <- as.character(mtcars$vs)
create_tabyls(mtcars, 'vs')
# vs n percent
# 0 18 56.2%
# 1 14 43.8%
# Total 32 -
或者另一个选项,如果我们使用不带引号的列名作为输入,那么我们可以使用 curly-curly 运算符 ({{}}
)
create_tabyls <- function(df,col_name) {
df %>%
tabyl({{col_name}}) %>%
adorn_pct_formatting() %>%
adorn_totals()
}
create_tabyls(mtcars, vs)
# vs n percent
# 0 18 56.2%
# 1 14 43.8%
# Total 32 -
或者如果我们需要两个选项,即字符串或不带引号的名称,则 ensym
和 !!
create_tabyls <- function(df,col_name) {
df %>%
tabyl(!! rlang::ensym(col_name)) %>%
adorn_pct_formatting() %>%
adorn_totals()
}
create_tabyls(mtcars, 'vs')
create_tabyls(mtcars, vs)
我对 R 比较陌生,正在尝试创建一个函数来应用于我想为其生成频率表的变量名列表。但是,我编写的函数打印函数的局部变量名称,而不是变量的实际名称。
create_tabyls <- function(df,col_name) {
result <- tabyl(df[[col_name]]) %>%
adorn_pct_formatting() %>%
adorn_totals()
print(result)
}
然后当我调用我的函数时:
create_tabyls(df,'AGE')
我得到:
df[[col_name]] n percent valid_percent
1 43141 3.5% 3.7%
2 810172 66.4% 69.7%
3 309058 25.3% 26.6%
<NA> 57246 4.7% -
Total 1219617 - -
我不明白为什么我的输出打印为 df[[col_name]] 而不是 df[[AGE]]。谁能帮我弄清楚我犯了什么错误?我试图让它打印我给函数的实际值,而不是仅仅打印函数变量的名称。
感谢您的帮助!
我们可以转换为 sym
bol 并计算 (!!
),因为输入是一个字符串
library(janitor)
library(dplyr)
create_tabyls <- function(df,col_name) {
df %>%
select(col_name) %>%
tabyl(!! rlang::sym(col_name)) %>%
adorn_pct_formatting() %>%
adorn_totals()
}
-测试
data(mtcars)
mtcars$vs <- as.character(mtcars$vs)
create_tabyls(mtcars, 'vs')
# vs n percent
# 0 18 56.2%
# 1 14 43.8%
# Total 32 -
或者另一个选项,如果我们使用不带引号的列名作为输入,那么我们可以使用 curly-curly 运算符 ({{}}
)
create_tabyls <- function(df,col_name) {
df %>%
tabyl({{col_name}}) %>%
adorn_pct_formatting() %>%
adorn_totals()
}
create_tabyls(mtcars, vs)
# vs n percent
# 0 18 56.2%
# 1 14 43.8%
# Total 32 -
或者如果我们需要两个选项,即字符串或不带引号的名称,则 ensym
和 !!
create_tabyls <- function(df,col_name) {
df %>%
tabyl(!! rlang::ensym(col_name)) %>%
adorn_pct_formatting() %>%
adorn_totals()
}
create_tabyls(mtcars, 'vs')
create_tabyls(mtcars, vs)