前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >奇怪的R语言apply问题及解决

奇怪的R语言apply问题及解决

作者头像
用户1075469
发布2022-11-08 13:51:57
5180
发布2022-11-08 13:51:57
举报
文章被收录于专栏:科技记者科技记者

今天遇到了一个百思不得解的问题,记录一下,欢迎交流讨论。为了简化问题,我把数据删除到两行,并把问题最小化了。我想用apply函数筛选一下第三列V4中的数据,用一个稍微复杂的条件,这里我简化成了是否大于0,当然,如果只是>0,太多方法可以实现了,只是复现最小错误。

代码语言:javascript
复制
# 原始数据如下:
# pca_test
# V1                 V2           V4
 1        1            439947 -0.000695291
 16035 2264 19307-P128  0.064951700

我最初的代码如下:

代码语言:javascript
复制
test_func <- function(row){
  print(row[3])
  row[3] > 0
}
apply(pca_test, 1, test_func)

才开始没打印出来的(此处省略n十分钟)。打印出来才发现问题所在,正数多了个空格(如蓝色空格所示),导致结果错误,但是单独放一行上去结果是OK的。就是这么神奇有没有,怎么解决呢,as.numeric转化成数值试试?

代码语言:javascript
复制
test_func <- function(row){
  print(as.numeric(row[3]))
  as.numeric(row[3]) > 0
}
apply(pca_test, 1, test_func)

问题解决啦!原因分析:

可能是因为会转化成字符串,导致空格多出来,或者是个bug。原来的数据结构如下:

数据处理过程中,需要的值变成了chr类型:

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-10-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微因 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档