首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在选择性列上拉皮()?-R

如何在选择性列上拉皮()?-R
EN

Stack Overflow用户
提问于 2017-04-10 03:04:57
回答 3查看 927关注 0票数 0

我是一个新手R程序员。我想知道如何在数据文件上轻拍,但避免使用某些列。

代码语言:javascript
运行
复制
# Some dummy dataframe
df <- data.frame(
         grp = c("A", "B", "C", "D"),
         trial = as.factor(c(1,1,2,2)),
         mean = as.factor(c(44,33,22,11)),
         sd = as.factor(c(3,4,1,.5)))

df <- lapply(df, function (x) {as.numeric(as.character(x))})

但是,我使用的方法是通过强制引入NAs。

在保持数据完整性的同时,会有选择地(或取消选择地)对数据文件进行lapply吗?

换句话说,会否有一种方法只将均值和sd转换为数字?(一般形式)

谢谢

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-04-10 03:11:54

尝试这样做:

代码语言:javascript
运行
复制
df[,3:4] <- lapply(df[,3:4], function (x) {as.numeric(as.character(x))})

您只是将函数传递给指定的列。您还可以提供一个条件来选择列的子集,比如排除不想转换的列。

代码语言:javascript
运行
复制
col = names(df)[names(df)!=c("grp","trial")]
df[,col] <- lapply(df[,col], function (x) {as.numeric(as.character(x))})
票数 2
EN

Stack Overflow用户

发布于 2017-04-10 03:11:43

正如你可能已经猜到的,有很多种方法。因为您似乎在执行就地替换,所以实际上,for循环是合适的。

代码语言:javascript
运行
复制
df <- data.frame(
         grp = c("A", "B", "C", "D"),
         trial = as.factor(c(1,1,2,2)),
         mean = as.factor(c(44,33,22,11)),
         sd = as.factor(c(3,4,1,.5)))

my_cols <- c("trial", "mean", "sd")
for(mc in my_cols) {
    df[[mc]] <- as.numeric(as.character(df[[mc]]))
}
票数 1
EN

Stack Overflow用户

发布于 2017-04-10 03:31:16

如果要按列名进行选择性转换:

代码语言:javascript
运行
复制
library(dplyr)
df %>% 
  mutate_if(names(.) %in% c("mean", "sd"), 
            function(x) as.numeric(as.character(x)))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43314396

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档