数据清洗必须会的一些方法 - sql篇

数据清洗是整个数据分析链路中非常重要的一个环节,能够提供更高的质量的数据,同时供应挖掘材料。

目录

一、介绍
二、解决质量问题
三、解决办法
    1.数据的完整性
    2.数据的唯一性
    3.数据的权威性
    4.数据的合法性
    5.数据的一致性

一、介绍

在进行数据分析之前,自己拿到的数据大部分情况下都是不能够直接用的,会存在很多数据质量的问题,这个时候就需要我们先过滤一遍。

数据清洗是整个数据分析链路中非常重要的一个环节,能够提供更高的质量的数据,同时供应挖掘材料。

二、解决质量问题

解决各种数据质量问题的目的,包括但不限于:

  • 数据的完整性 —— 例如,人的属性中缺少性别、籍贯、年龄等

  • 数据的唯一性 —— 例如,不同来源的数据重复出现的情况

  • 数据的权威性 —— 例如,同一个指标出现多个来源的数据,且数值不一样

  • 数据的合法性 —— 例如,获取的数据与常识不符,年龄大于150岁。

  • 数据的一致性 —— 例如,不同来源的不同指标,实际内涵是一样的,或是同一指标内涵不一致。

数据清洗的结果是对各种脏数据进行对应方式的处理,得到标准的、干净的、连续的数据,提供给数据统计、数据挖掘等使用。

三、解决办法

1. 数据的完整性

思路:数据缺失,那么补上就好了。

首先判断能不能从源头上直接补上,这部分的数据缺失太多,是否研发那边某个埋点的功能异常,导致一些数据无法上报,这个时候需要找研发对接。

如果是正常的数据丢失率例如1%-2%左右,那么可以具体通过一下一些方式不上数据:

  • 通过其他信息补全,例如使用身份证件号推算性别、籍贯、出生日期、年龄等

  • 通过前后数据补齐,例如时间序列数据确实了,可以使用前后的均值,缺的多了,可以使用平滑等处理。均值、中位数,或者自动向上或者向下补齐都是比较常用的方法。

  • 实在补不全的,虽然很可惜,但也必须要剔除。但是不要删掉,没准以后用的上。

sql处理方式


#查看comm字段缺失数量

select sum(comm is null) from emp;

# 平均值填充

select ifnull(comm,(select avg(comm) from emp)) from emp;

# 也可以使用coalesce()函数,该函数将多个表达式或列作为参数,并返回第一个非空的值

select coalesce(comm,0) from emp; # 将null值填充为0

2. 数据的唯一性

思路:去除重复记录,只保留一条。

去重的方法有:

  • 按主键去重,用sql 『去除重复记录』即可。

  • 按规则去重,编写一系列规则,对重复情况复杂的数据进行去重。例如不同渠道来的客户数据,可以通过相同的关键信息进行匹配,合并去重。

sql处理方式


# 去重单个字段

select distinct comm from emp;

# 使用group by + 聚合函数例如max,min,any_value

# 去重多个字段,设定一个student表,其中,同一个学生可能有两个age值

select name,any_value(age) from student group by name

select name,max(age) from student group by name

any_value()会选择被分到同一组的数据里第一条数据的指定列值作为返回数据

3. 数据的权威性

思路:用最权威的那个渠道的数据

方法:对不同渠道设定权威级别

4. 数据的合法性

思路:设定判定规则

  • 设定强制合法规则,凡是不在此规则范围内的,强制设为最大值,或者判为无效,剔除

  • 字段类型合法规则:日期字段格式为『2010-10-10』

  • 字段内容合法规则:性别 in (男、女、未知);出生日期<=今天

  • 设定告警规则,凡是不再此规则范围内的,进行告警,然后人工处理

  • 告警规则:年龄 > 110

  • 离群值人工特殊处理,使用分箱、聚类、回归、等方法发现离群值

sql处理方式


# 使用where条件进行限制

select name,sex,age from student

where sex in ("男","女","未知")

and age between 0 and 110

5. 数据的一致性问题

思路:建立元数据体系,包括但不限于:指标体系(度量)、维度(分组、统计口径)、单位、频度、数据。

tips:如果数据质量问题比较严重,建议跟技术团队好好聊聊。

供应算法原料的数据处理方式,下一篇文章见。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,980评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,422评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,130评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,553评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,408评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,326评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,720评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,373评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,678评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,722评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,486评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,335评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,738评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,283评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,692评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,893评论 2 335

推荐阅读更多精彩内容