0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

常用數(shù)據(jù)清洗的SQL對(duì)比版

人工智能與大數(shù)據(jù)技術(shù) ? 來(lái)源:數(shù)據(jù)管道 ? 作者:寶器 ? 2022-09-13 10:32 ? 次閱讀

日常工作中,分析師會(huì)接到一些專項(xiàng)分析的需求,首先會(huì)搜索腦中的分析體悉,根據(jù)業(yè)務(wù)需求構(gòu)建相應(yīng)的分析模型(不只是機(jī)器學(xué)習(xí)模型),根據(jù)模型填充相應(yīng)維度表,這些維度特征表能夠被使用的前提是假設(shè)已經(jīng)清洗干凈了。

但真正的原始表是混亂且包含了很多無(wú)用的冗余特征,所以能夠根據(jù)原始數(shù)據(jù)清洗出相對(duì)干凈的特征表就很重要。

前兩天在Towards Data Science上看到一篇文章,講的是用Pandas做數(shù)據(jù)清洗,作者將常用的清洗邏輯封裝成了一個(gè)個(gè)的清洗函數(shù)。

公司的業(yè)務(wù)數(shù)據(jù)一般存儲(chǔ)在數(shù)據(jù)倉(cāng)庫(kù)里面,數(shù)據(jù)量很大,這時(shí)候用Pandas處理是不大方便的,更多時(shí)候用的是HiveSQL和MySql做處理。

基于此,我拓展了部分內(nèi)容,寫(xiě)了一個(gè)常用數(shù)據(jù)清洗的SQL對(duì)比版,腳本很簡(jiǎn)單,重點(diǎn)是這些清洗場(chǎng)景和邏輯,大綱如圖:

adc1ad48-3305-11ed-ba43-dac502259ad0.png

01 刪除指定列、重命名列

場(chǎng)景

多數(shù)情況并不是底表的所有特征(列)都對(duì)分析有用,這個(gè)時(shí)候就只需要抽取部分列,對(duì)于不用的那些列,可以刪除。

重命名列可以避免有些列的命名過(guò)于冗長(zhǎng)(比如Case When 語(yǔ)句),且有時(shí)候會(huì)根據(jù)不同的業(yè)務(wù)指標(biāo)需求來(lái)命名。

刪除列Python版:
df.drop(col_names,axis=1,inplace=True)

刪除列SQL版:
1、selectcol_namesfromTable_Name

2、altertabletableNamedropcolumncolumnName

重命名列Python版:
df.rename(index={'row1':'A'},columns={'col1':'B'})

重命名列SQL版:
selectcol_namesascol_name_BfromTable_Name

因?yàn)橐话闱闆r下是沒(méi)有刪除的權(quán)限(可以構(gòu)建臨時(shí)表),反向思考,刪除的另一個(gè)邏輯是選定指定列(Select)。

02 重復(fù)值、缺失值處理

場(chǎng)景:比如某網(wǎng)站今天來(lái)了1000個(gè)人訪問(wèn),但一個(gè)人一天中可以訪問(wèn)多次,那數(shù)據(jù)庫(kù)中會(huì)記錄用戶訪問(wèn)的多條記錄,而這時(shí)候如果想要找到今天訪問(wèn)這個(gè)網(wǎng)站的1000個(gè)人的ID并根據(jù)此做用戶調(diào)研,需要去掉重復(fù)值給業(yè)務(wù)方去回訪。

缺失值:NULL做運(yùn)算邏輯時(shí),返回的結(jié)果還是NULL,這可能就會(huì)出現(xiàn)一些腳本運(yùn)行正確,但結(jié)果不對(duì)的BUG,此時(shí)需要將NULL值填充為指定值。

重復(fù)值處理Python版:
df.drop_duplicates()

重復(fù)值處理SQL版:
1、selectdistinctcol_namefromTable_Name

2、selectcol_namefromTable_Namegroupbycol_name

缺失值處理Python版:
df.fillna(value=0)

df1.combine_first(df2)

缺失值處理SQL版:
1、selectifnull(col_name,0)valuefromTable_Name

2、selectcoalesce(col_name,col_name_A,0)asvaluefromTable_Name

3、selectcasewhencol_nameisnullthen0elsecol_nameendfromTable_Name

03 替換字符串空格、清洗*%@等垃圾字符、字符串拼接、分隔等字符串處理

場(chǎng)景:理解用戶行為的重要一項(xiàng)是去假設(shè)用戶的心理,這會(huì)用到用戶的反饋意見(jiàn)或一些用研的文本數(shù)據(jù),這些文本數(shù)據(jù)一般會(huì)以字符串的形式存儲(chǔ)在數(shù)據(jù)庫(kù)中,但用戶反饋的這些文本一般都會(huì)很亂,所以需要從這些臟亂的字符串中提取有用信息,就會(huì)需要用到文字符串處理函數(shù)。

字符串處理Python版:
##1、空格處理
df[col_name]=df[col_name].str.lstrip()

##2、*%d等垃圾符處理
df[col_name].replace('&#.*','',regex=True,inplace=True)

##3、字符串分割
df[col_name].str.split('分割符')

##4、字符串拼接
df[col_name].str.cat()

字符串處理SQL版:
##1、空格處理
selectltrim(col_name)fromTable_name

##2、*%d等垃圾符處理
selectregexp_replace(col_name,正則表達(dá)式)fromTable_name

##3、字符串分割
selectsplit(col_name,'分割符')fromTable_name

##4、字符串拼接
selectconcat_ws(col_name,'拼接符')fromTable_name

04 合并處理

場(chǎng)景:有時(shí)候你需要的特征存儲(chǔ)在不同的表里,為便于清洗理解和操作,需要按照某些字段對(duì)這些表的數(shù)據(jù)進(jìn)行合并組合成一張新的表,這樣就會(huì)用到連接等方法。

合并處理Python版:

左右合并
1、pd.merge(left,right,how='inner',on=None,left_on=None,right_on=None,
left_index=False,right_index=False,sort=True,
suffixes=('_x','_y'),copy=True,indicator=False,
validate=None)
2、pd.concat([df1,df2])

上下合并
df1.append(df2,ignore_index=True,sort=False)

合并處理SQL版:

左右合并
selectA.*,B.*fromTable_aAjoinTable_bBonA.id=B.id

selectA.*fromTable_aAleftjoinTable_bBonA.id=B.id

上下合并
## Union:對(duì)兩個(gè)結(jié)果集進(jìn)行并集操作,不包括重復(fù)行,同時(shí)進(jìn)行默認(rèn)規(guī)則的排序;
## Union All:對(duì)兩個(gè)結(jié)果集進(jìn)行并集操作,包括重復(fù)行,不進(jìn)行排序;

selectA.*fromTable_aA
union
selectB.*fromTable_bB

# Union 因?yàn)闀?huì)將各查詢子集的記錄做比較,故比起Union All ,通常速度都會(huì)慢上許多。一般來(lái)說(shuō),如果使用Union All能滿足要求的話,務(wù)必使用Union All。
05、窗口函數(shù)的分組排序

場(chǎng)景:假如現(xiàn)在你是某寶的分析師,要分析今年不同店的不同品類銷售量情況,需要找到那些銷量較好的品類,并在第二年中加大曝光,這個(gè)時(shí)候你就需要將不同店里不同品類進(jìn)行分組,并且按銷量進(jìn)行排序,以便查找到每家店銷售較好的品類。

addca792-3305-11ed-ba43-dac502259ad0.png

Demo數(shù)據(jù)如上,一共a,b,c三家店鋪,賣了不同品類商品,銷量對(duì)應(yīng)如上,要找到每家店賣的最多的商品。
窗口分組Python版:

df['Rank']=df.groupby(by=['Sale_store'])['Sale_Num'].transform(lambdax:x.rank(ascending=False))

窗口分組SQL版:

select
*
from
(
Select
*,
row_number()over(partitionbySale_storeorderbySale_Numdesc)rk
from
table_name
)bwhereb.rk=1

ae012900-3305-11ed-ba43-dac502259ad0.png

可以很清晰的看到,a店鋪賣的最火的是蔬菜,c店鋪賣的最火的是雞肉,b店鋪?

嗯,b店鋪很不錯(cuò),賣了888份寶器狗。

總結(jié),上面的內(nèi)容核心是掌握這些數(shù)據(jù)清洗的應(yīng)用場(chǎng)景,這些場(chǎng)景幾乎可以涵蓋90%的數(shù)據(jù)分析前數(shù)據(jù)清洗的內(nèi)容。而對(duì)于分析模型來(lái)說(shuō),SQL和Python都是工具,如果熟悉SQL,是能夠更快速、方便的將特征清洗用SQL實(shí)現(xiàn)。

所以,請(qǐng)別張口閉口數(shù)據(jù)科學(xué),你竟SQL都不會(huì)。




審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • SQL
    SQL
    +關(guān)注

    關(guān)注

    1

    文章

    751

    瀏覽量

    43994
  • MySQL
    +關(guān)注

    關(guān)注

    1

    文章

    794

    瀏覽量

    26359
  • 機(jī)器學(xué)習(xí)

    關(guān)注

    66

    文章

    8325

    瀏覽量

    132213
  • python
    +關(guān)注

    關(guān)注

    54

    文章

    4759

    瀏覽量

    84298

原文標(biāo)題:5大SQL數(shù)據(jù)清洗方法!

文章出處:【微信號(hào):TheBigData1024,微信公眾號(hào):人工智能與大數(shù)據(jù)技術(shù)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    數(shù)據(jù)從業(yè)者必知必會(huì)的Hive SQL調(diào)優(yōu)技巧

    數(shù)據(jù)從業(yè)者必知必會(huì)的Hive SQL調(diào)優(yōu)技巧 摘要 :在大數(shù)據(jù)領(lǐng)域中,Hive SQL被廣泛應(yīng)用于數(shù)據(jù)倉(cāng)庫(kù)的
    的頭像 發(fā)表于 09-24 13:30 ?118次閱讀

    數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)—SQL Server數(shù)據(jù)庫(kù)出現(xiàn)823錯(cuò)誤的數(shù)據(jù)恢復(fù)案例

    SQL Server數(shù)據(jù)庫(kù)故障: SQL Server附加數(shù)據(jù)庫(kù)出現(xiàn)錯(cuò)誤823,附加數(shù)據(jù)庫(kù)失敗。數(shù)據(jù)
    的頭像 發(fā)表于 09-20 11:46 ?235次閱讀
    <b class='flag-5'>數(shù)據(jù)</b>庫(kù)<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—<b class='flag-5'>SQL</b> Server<b class='flag-5'>數(shù)據(jù)</b>庫(kù)出現(xiàn)823錯(cuò)誤的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    什么是 Flink SQL 解決不了的問(wèn)題?

    簡(jiǎn)介 在實(shí)時(shí)數(shù)據(jù)開(kāi)發(fā)過(guò)程中,大家經(jīng)常會(huì)用 Flink SQL 或者 Flink DataStream API 來(lái)做數(shù)據(jù)加工。通常情況下選用2者都能加工出想要的數(shù)據(jù),但是總會(huì)有 Flin
    的頭像 發(fā)表于 07-09 20:50 ?213次閱讀

    超聲波清洗機(jī)常用的頻率及清洗特點(diǎn)

    超聲波清洗機(jī)是一種利用超聲波振動(dòng)原理進(jìn)行清洗的設(shè)備,廣泛應(yīng)用于工業(yè)、醫(yī)療、實(shí)驗(yàn)室等領(lǐng)域。不同的超聲波清洗機(jī)使用的頻率不同,而頻率的不同也會(huì)影響到清洗的效果和特點(diǎn)。本文將對(duì)超聲波
    的頭像 發(fā)表于 04-15 14:14 ?2755次閱讀
    超聲波<b class='flag-5'>清洗</b>機(jī)<b class='flag-5'>常用</b>的頻率及<b class='flag-5'>清洗</b>特點(diǎn)

    火電廠凝汽器不停車在線清洗與凝汽器停車清洗八種技術(shù)對(duì)比分析

    通過(guò)凝汽器結(jié)垢對(duì)發(fā)電機(jī)組運(yùn)行安全性和經(jīng)濟(jì)性的影響分析,以及對(duì)火電行業(yè)現(xiàn)有凝汽器清洗技術(shù)的優(yōu)劣對(duì)比介紹,并通過(guò)火電廠凝汽器在線化學(xué)清洗技術(shù)案例,對(duì)清洗前后凝汽器運(yùn)行性能
    的頭像 發(fā)表于 03-21 19:57 ?381次閱讀
    火電廠凝汽器不停車在線<b class='flag-5'>清洗</b>與凝汽器停車<b class='flag-5'>清洗</b>八種技術(shù)<b class='flag-5'>對(duì)比</b>分析

    MySQL的執(zhí)行過(guò)程 SQL語(yǔ)句性能優(yōu)化常用策略

    回顧 MySQL 的執(zhí)行過(guò)程,幫助介紹如何進(jìn)行 sql 優(yōu)化。
    的頭像 發(fā)表于 12-12 10:26 ?582次閱讀
    MySQL的執(zhí)行過(guò)程 <b class='flag-5'>SQL</b>語(yǔ)句性能優(yōu)化<b class='flag-5'>常用</b>策略

    oracle執(zhí)行sql查詢語(yǔ)句的步驟是什么

    Oracle數(shù)據(jù)庫(kù)是一種常用的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),具有強(qiáng)大的SQL查詢功能。Oracle執(zhí)行SQL查詢語(yǔ)句的步驟包括編寫(xiě)
    的頭像 發(fā)表于 12-06 10:49 ?854次閱讀

    oracle sql 定義變量并賦值

    在Oracle SQL中,變量是用來(lái)存儲(chǔ)數(shù)據(jù)值的標(biāo)識(shí)符。通過(guò)定義和使用變量,我們可以在SQL語(yǔ)句中使用它們來(lái)存儲(chǔ)和處理數(shù)據(jù),從而實(shí)現(xiàn)更靈活和動(dòng)態(tài)的查詢和操作。 在Oracle
    的頭像 發(fā)表于 12-06 10:46 ?2399次閱讀

    SQL Server數(shù)據(jù)庫(kù)備份方法

    SQL Server是一種用于管理和存儲(chǔ)數(shù)據(jù)的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)。備份數(shù)據(jù)庫(kù)是保護(hù)和恢復(fù)數(shù)據(jù)的重要措施之一,以防止意外
    的頭像 發(fā)表于 11-23 14:27 ?1289次閱讀

    sql數(shù)據(jù)庫(kù)入門基礎(chǔ)知識(shí)

    庫(kù)開(kāi)發(fā)人員或數(shù)據(jù)庫(kù)管理員的重要基礎(chǔ)。本文將介紹SQL的入門基礎(chǔ)知識(shí),詳細(xì)介紹SQL的語(yǔ)法、常用操作以及一些實(shí)用技巧。 一、SQL的基本概念和
    的頭像 發(fā)表于 11-23 14:24 ?1821次閱讀

    sql語(yǔ)句多個(gè)條件怎么連接

    SQL中,多個(gè)條件可以使用邏輯運(yùn)算符連接,常用的邏輯運(yùn)算符有AND、OR和NOT。這些運(yùn)算符可以幫助我們?cè)诓樵冎兄付ǘ鄠€(gè)條件以過(guò)濾數(shù)據(jù),從而獲得我們需要的結(jié)果集。 AND運(yùn)算符用于同時(shí)滿足多個(gè)條件
    的頭像 發(fā)表于 11-23 11:34 ?2123次閱讀

    sql語(yǔ)句where條件查詢

    SQL是一種用于管理和操作關(guān)系型數(shù)據(jù)庫(kù)的編程語(yǔ)言。其中,WHERE子句是用于過(guò)濾查詢結(jié)果的重要部分。通過(guò)WHERE條件,我們可以指定一系列條件,以僅返回滿足條件的記錄。本文將探討WHERE條件查詢
    的頭像 發(fā)表于 11-23 11:28 ?1039次閱讀

    mysql和sql server區(qū)別

    MySQL和SQL Server是兩種常見(jiàn)的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)(RDBMS),用于存儲(chǔ)和管理數(shù)據(jù)庫(kù)。雖然它們都支持SQL語(yǔ)言,但在其他方面存在一些顯著的區(qū)別。以下是MySQL和
    的頭像 發(fā)表于 11-21 11:07 ?1398次閱讀

    sql中日期函數(shù)的用法

    日期函數(shù)在SQL中是非常重要的功能之一,它們能幫助我們?cè)?b class='flag-5'>數(shù)據(jù)庫(kù)中存儲(chǔ)和處理日期和時(shí)間數(shù)據(jù)。在本文中,我將詳細(xì)介紹一些常用SQL日期函數(shù),包
    的頭像 發(fā)表于 11-17 16:24 ?887次閱讀

    labview MS SQL數(shù)據(jù)庫(kù),數(shù)據(jù)插入問(wèn)題

    萌新求助,這個(gè)SQL數(shù)據(jù)插入是什么問(wèn)題啊
    發(fā)表于 11-08 14:49