楼主: themlbb
1996 5

[问答] 请问除了for循环,还有更好的方法对数据框的多列进行相同操作吗? [推广有奖]

  • 3关注
  • 2粉丝

已卖:171份资源

博士生

90%

还不是VIP/贵宾

-

威望
0
论坛币
2807 个
通用积分
9.4068
学术水平
1 点
热心指数
2 点
信用等级
1 点
经验
4230 点
帖子
172
精华
0
在线时间
536 小时
注册时间
2010-2-27
最后登录
2023-3-20

楼主
themlbb 发表于 2019-4-11 21:57:03 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
用within对数据框进行操作,好像都只能一列一列的来如果对多列采用同一种操作,要怎么实现呢?
比如都用gsub进行正则匹配替换相应字符串? 除了for循环外,还有啥好方法

还有就是如果想对数据框的多列(并非全部)的缺失值替换成0
除了for循环外,不懂还有没有啥写得简便的方法?

感谢大神帮助!!
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:缺失值替换 正则匹配 字符串 缺失值 有没有

沙发
cheetahfly 在职认证  发表于 2019-4-11 23:30:29
library(tidyverse)
df %>%
  mutate_at(.vars = vars(...你要操作的列...), .fun = function(x) ifelse(is.na(x), 0, x))
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
Sunknownay + 3 + 3 + 3 精彩帖子

总评分: 学术水平 + 3  热心指数 + 3  信用等级 + 3   查看全部评分

藤椅
themlbb 发表于 2019-4-12 18:16:10
cheetahfly 发表于 2019-4-11 23:30
library(tidyverse)
df %>%
  mutate_at(.vars = vars(...你要操作的列...), .fun = function(x) ifelse( ...
感谢大神,感觉发现了新世界

板凳
小朝 发表于 2019-4-12 18:17:57
  1. a <- data.frame(a1=c(1,2,NA),a2=c(NA,2,3),a3=c(3,NA,4))
  2. a[,c(2,3)][is.na(a[,c(2,3)])] <- 0
复制代码


缺失值填充比较简单,复杂的也可以用apply族
已有 1 人评分论坛币 收起 理由
cheetahfly + 10 热心帮助其他会员

总评分: 论坛币 + 10   查看全部评分

报纸
caimiao0714 学生认证  发表于 2019-4-12 22:52:45
如果你是对数据框所有的数据进行缺失值替换成0的话,还有个更简洁的办法:

  1. dat[is.na(dat)] = 0
复制代码

地板
nieqiang110 学生认证  发表于 2019-4-13 06:59:44
purrr包,看看,很好用

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-25 15:56