将列表中 data.frames 中的列从因子转换为数字
Convert from factor to numeric a column in data.frames within a list
这是我的两个列表和相关代码的示例:
df1 = data.frame(a = c(1,1,1,2,3,3,4,4,5,6,6,7,8,9,9,10))
df2 = data.frame(a = c(1,2,2,2,3,4,5,5,6,6,7,8,9,9,10,10,11))
lst = list(df1, df2)
lst_table = lapply(lst, function(x) data.frame(table(x$a)))
> class(lst_table[[1]]$Var1)
[1] "factor"
> class(lst_table[[2]]$Var1)
[1] "factor"
由于我的代码目的,我需要列表中每个 data.frame 中的列 Var1
是一个数字向量。
从 How to convert a factor to an integer\numeric without a loss of information? 开始,我将以下代码应用于单个 data.frames 并且有效:
> df1$a = as.numeric(levels(df1$a))[df1$a]
> df2$a = as.numeric(levels(df2$a))[df2$a]
> class(df1$a)
[1] "numeric"
> class(df2$a)
[1] "numeric"
但是我怎样才能将上面的内容应用到列表中呢?
我试过了:
lst_table = lapply(lst_table, function(y) {y$Var1 = as.numeric(levels(y$Var1))[y$Var1]})
但是没用。
有什么建议吗?
谢谢
我认为问题在于你的第二个 lapply
中的函数只返回数字因子水平的向量,而不是整个 data.frame
。我相信以下应该有效:
foo <- function(y) {
y$Var1 <- as.numeric(levels(y$Var1))[y$Var1]
return(y)
}
lst_table <- lapply(lst_table, foo)
这是我的两个列表和相关代码的示例:
df1 = data.frame(a = c(1,1,1,2,3,3,4,4,5,6,6,7,8,9,9,10))
df2 = data.frame(a = c(1,2,2,2,3,4,5,5,6,6,7,8,9,9,10,10,11))
lst = list(df1, df2)
lst_table = lapply(lst, function(x) data.frame(table(x$a)))
> class(lst_table[[1]]$Var1)
[1] "factor"
> class(lst_table[[2]]$Var1)
[1] "factor"
由于我的代码目的,我需要列表中每个 data.frame 中的列 Var1
是一个数字向量。
从 How to convert a factor to an integer\numeric without a loss of information? 开始,我将以下代码应用于单个 data.frames 并且有效:
> df1$a = as.numeric(levels(df1$a))[df1$a]
> df2$a = as.numeric(levels(df2$a))[df2$a]
> class(df1$a)
[1] "numeric"
> class(df2$a)
[1] "numeric"
但是我怎样才能将上面的内容应用到列表中呢?
我试过了:
lst_table = lapply(lst_table, function(y) {y$Var1 = as.numeric(levels(y$Var1))[y$Var1]})
但是没用。
有什么建议吗? 谢谢
我认为问题在于你的第二个 lapply
中的函数只返回数字因子水平的向量,而不是整个 data.frame
。我相信以下应该有效:
foo <- function(y) {
y$Var1 <- as.numeric(levels(y$Var1))[y$Var1]
return(y)
}
lst_table <- lapply(lst_table, foo)