鱼C论坛

 找回密码
 立即注册
查看: 524|回复: 2

如何记录异常数值的列名?

[复制链接]
发表于 2019-5-16 11:20:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 老笨啊 于 2019-5-16 14:02 编辑

我手头有一组数据,其中有些异常值,已经被替换成了-1值。
我需要新生成一列,列中注明每行数据中,那几列的数值是异常的。。具体代码该怎么写呢?

1. 数据大致情况如下:(我需要在remark列的每一行中,注明当前行的那几列数据有异常)
12.png

我的代码如下,但是貌似无法将多列数值记录下来:
  1. def remark(x):
  2.     for a in data.columns:
  3.         outrange =[]
  4.         if x[a] == -1:
  5.             outrange.append(a)  #当前行如有多列数值异常,全部纳入列表中
  6.             return '%s outrange'%(','.join(outrange))  #输出时,用逗号将列表中的元素连接起来,并转成字符串
  7. data['remark'] = data.apply(remark,axis=1)
  8. data
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-5-16 14:04:31 | 显示全部楼层
2.png
自己改了一会代码,但是出来的结果,却只能适合单列数值有异常的。。
如果是多列数值有异常的话,无法记录多列。。
求指点,如何改进。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-5-16 15:12:29 | 显示全部楼层
折腾半天,自己终于解决了。。
  1. def remark(x):
  2.     outrange =[]
  3.     for a in data.columns:        
  4.         if x[a] == -1:
  5.             outrange.append(a)  #当前行如有多列数值异常,全部纳入列表中
  6.     if len(outrange):
  7.         return '%s outrange'%(','.join(outrange))  #输出时,用逗号将列表中的元素连接起来,并转成字符串
  8. data['remark'] = data.apply(remark,axis=1)
  9. data
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-1-15 20:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表