
作者 | 磐懟懟
來(lái)源 | 磐創(chuàng)AI
數(shù)據(jù)科學(xué)家是“在統(tǒng)計(jì)方面比任何軟件工程師都要出色,在軟件工程方面比任何統(tǒng)計(jì)學(xué)家都出色的人”。許多數(shù)據(jù)科學(xué)家都有統(tǒng)計(jì)學(xué)背景,但很少有軟件工程經(jīng)驗(yàn)。我是一位高級(jí)數(shù)據(jù)科學(xué)家,在Python編碼的Stackoverflow上排名第一,并與許多(初級(jí))數(shù)據(jù)科學(xué)家合作。下面是我經(jīng)??吹降?0個(gè)常見(jiàn)錯(cuò)誤。
1. 不共享代碼中引用的數(shù)據(jù)
數(shù)據(jù)科學(xué)需要代碼和數(shù)據(jù)。因此,要使其他人能夠重現(xiàn)您的結(jié)果,他們需要有權(quán)訪問(wèn)數(shù)據(jù)。雖然看起來(lái)很基礎(chǔ),但是很多人忘記了共享代碼的數(shù)據(jù)。
import pandas as pd
df1 = pd.read_csv('file-i-dont-have.csv') # 錯(cuò)誤
do_stuff(df)
解決方案:使用d6tpipe共享數(shù)據(jù)文件,或上傳到S3 / web / google等或保存到數(shù)據(jù)庫(kù),以他人可以檢索文件(但不要將它們添加到git,詳見(jiàn)下文)。
2. 硬編碼無(wú)法訪問(wèn)的路徑
與錯(cuò)誤1相似,如果您對(duì)其他人無(wú)法訪問(wèn)的路徑進(jìn)行硬編碼,則他們將無(wú)法運(yùn)行您的代碼,因此要查看很多地方手動(dòng)更改路徑。
import pandas as pd
df = pd.read_csv('/path/i-dont/have/data.csv') # 錯(cuò)誤
do_stuff(df)
# or
impor os
os.chdir('c:\\Users\\yourname\\desktop\\python') # 錯(cuò)誤
解決方案:使用相對(duì)路徑,配置全局路徑變量或d6tpipe使數(shù)據(jù)易于訪問(wèn)。
3. 將數(shù)據(jù)與代碼混合
由于數(shù)據(jù)科學(xué)代碼需要數(shù)據(jù),為什么不將其存儲(chǔ)到同一目錄?當(dāng)您使用它時(shí),也可以在其中保存圖像,日志和其他垃圾文件。
├── data.csv ├── ingest.py ├── other-data.csv ├── output.png ├── report.html └── run.py
解決方案:將目錄按照類別進(jìn)行組織,例如數(shù)據(jù),日志,代碼等。
4. Git提交帶有源代碼的數(shù)據(jù)
現(xiàn)在大多數(shù)人都可以控制他們的代碼版本(如果不使用,那是另一個(gè)錯(cuò)誤!參見(jiàn)git)。為了共享數(shù)據(jù),可能想將數(shù)據(jù)文件添加到版本控制中。如果是很小的文件還可以,但是git并沒(méi)有對(duì)數(shù)據(jù)文件進(jìn)行優(yōu)化,尤其是大文件。
git add data.csv
解決方案:使用問(wèn)題1中提到的工具來(lái)存儲(chǔ)和共享數(shù)據(jù)。如果確實(shí)要對(duì)控制數(shù)據(jù)進(jìn)行版本控制,請(qǐng)參閱d6tpipe,DVC和Git大文件存儲(chǔ)。
5. 編寫(xiě)函數(shù)而不是DAG
有足夠的數(shù)據(jù),接下來(lái)談?wù)剬?shí)際的代碼!由于在學(xué)習(xí)代碼時(shí)首先要學(xué)習(xí)的內(nèi)容之一就是函數(shù),因此數(shù)據(jù)科學(xué)代碼通常被組織為一系列線性運(yùn)行的函數(shù)。這可能會(huì)導(dǎo)致幾個(gè)問(wèn)題。
def process_data(data, parameter): data = do_stuff(data) data.to_pickle('data.pkl') data = pd.read_csv('data.csv') process_data(data) df_train = pd.read_pickle(df_train) model = sklearn.svm.SVC() model.fit(df_train.iloc[:,:-1], df_train['y'])
解決方案:最好將數(shù)據(jù)科學(xué)代碼編寫(xiě)為一組任務(wù),并且它們之間具有依賴性,而不是線性鏈接函數(shù)。使用d6tflow或airflow。
6. 循環(huán)
和函數(shù)一樣,for循環(huán)是在學(xué)習(xí)編碼時(shí)首先要學(xué)習(xí)的東西。它們易于理解,但它們速度慢且過(guò)于冗長(zhǎng),通常表示您不知道有向量化的替代方案。
x = range(10) avg = sum(x)/len(x); std = math.sqrt(sum((i-avg)**2 for i in x)/len(x)); zscore = [(i-avg)/std for x] # should be: scipy.stats.zscore(x) # or groupavg = [] for i in df['g'].unique(): dfg = df[df[g']==i] groupavg.append(dfg['g'].mean()) # should be: df.groupby('g').mean()
解決方案:Numpy,scipy和pandas具有向量化功能,可用于大多數(shù)的循環(huán)。
7. 不編寫(xiě)單元測(cè)試
隨著數(shù)據(jù),參數(shù)或用戶輸入的更改,您的代碼可能會(huì)中斷,有時(shí)您可能不會(huì)注意到。這可能會(huì)導(dǎo)致錯(cuò)誤的輸出,如果有人根據(jù)您的輸出做出決策,那么錯(cuò)誤的數(shù)據(jù)將導(dǎo)致錯(cuò)誤的決策!
解決方案:使用assert語(yǔ)句檢查數(shù)據(jù)。pandas有相等測(cè)試,d6tstack有數(shù)據(jù)攝取和檢查,d6tjoin數(shù)據(jù)連接。代碼示例:
assert df['id'].unique().shape[0] == len(ids) # 數(shù)據(jù)是否有所有的id assert df.isna().sum()<0.9 # 檢查缺失的數(shù)據(jù) assert df.groupby(['g','date']).size().max() ==1 # 是否有重復(fù)的數(shù)據(jù) assert d6tjoin.utils.PreJoin([df1,df2],['id','date']).is_all_matched() # 所有的id是否匹配
8. 不記錄代碼
我明白你著急進(jìn)行一些分析。您可以一起努力取得成果給客戶或老板。然后一個(gè)星期后,他們說(shuō)“請(qǐng)您更新此內(nèi)容”。您看著您的代碼,不記得為什么要這么做?,F(xiàn)在想象其他人需要運(yùn)行它。
def some_complicated_function(data):
data = data[data['column']!='wrong']
data = data.groupby('date').apply(lambda x: complicated_stuff(x))
data = data[data['value']<0.9]
return data
解決方案:即使在完成分析之后,也要花點(diǎn)時(shí)間記錄所做的工作。您將感謝自己,其他人更加感謝!
9. 將數(shù)據(jù)另存為csv或pickle
回到數(shù)據(jù),畢竟是數(shù)據(jù)科學(xué)。就像函數(shù)和for循環(huán)一樣,通常使用CSV和pickle文件,但它們實(shí)際上并不是很好。CSV不包含架構(gòu),因此每個(gè)人都必須再次解析數(shù)字和日期。pickle可以解決此問(wèn)題,但只能在python中工作,并且不能壓縮。兩者都不是存儲(chǔ)大型數(shù)據(jù)集的良好格式。
def process_data(data, parameter): data = do_stuff(data) data.to_pickle('data.pkl') data = pd.read_csv('data.csv') process_data(data) df_train = pd.read_pickle(df_train)
解決方案:使用parquet 或其他具有數(shù)據(jù)格式的二進(jìn)制數(shù)據(jù)格式,最好是壓縮數(shù)據(jù)的格式。d6tflow自動(dòng)將任務(wù)的數(shù)據(jù)輸出保存為parquet,不需要你進(jìn)行處理。
10. 使用jupyter筆記本
讓我們以一個(gè)有爭(zhēng)議的結(jié)論來(lái)結(jié)束:jupyter notebooks 與CSV一樣普遍。很多人使用它們,那并不是好事。Jupyter notebooks 促進(jìn)了上述許多不良的軟件工程習(xí)慣,尤其是:
入門(mén)很容易,但是擴(kuò)展性很差。
解決方案:使用pycharm或spyder。
數(shù)據(jù)分析咨詢請(qǐng)掃描二維碼
若不方便掃碼,搜微信號(hào):CDAshujufenxi
LSTM 模型輸入長(zhǎng)度選擇技巧:提升序列建模效能的關(guān)鍵? 在循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)家族中,長(zhǎng)短期記憶網(wǎng)絡(luò)(LSTM)憑借其解決長(zhǎng)序列 ...
2025-07-11CDA 數(shù)據(jù)分析師報(bào)考條件詳解與準(zhǔn)備指南? ? 在數(shù)據(jù)驅(qū)動(dòng)決策的時(shí)代浪潮下,CDA 數(shù)據(jù)分析師認(rèn)證愈發(fā)受到矚目,成為眾多有志投身數(shù) ...
2025-07-11數(shù)據(jù)透視表中兩列相乘合計(jì)的實(shí)用指南? 在數(shù)據(jù)分析的日常工作中,數(shù)據(jù)透視表憑借其強(qiáng)大的數(shù)據(jù)匯總和分析功能,成為了 Excel 用戶 ...
2025-07-11尊敬的考生: 您好! 我們誠(chéng)摯通知您,CDA Level I和 Level II考試大綱將于 2025年7月25日 實(shí)施重大更新。 此次更新旨在確保認(rèn) ...
2025-07-10BI 大數(shù)據(jù)分析師:連接數(shù)據(jù)與業(yè)務(wù)的價(jià)值轉(zhuǎn)化者? ? 在大數(shù)據(jù)與商業(yè)智能(Business Intelligence,簡(jiǎn)稱 BI)深度融合的時(shí)代,BI ...
2025-07-10SQL 在預(yù)測(cè)分析中的應(yīng)用:從數(shù)據(jù)查詢到趨勢(shì)預(yù)判? ? 在數(shù)據(jù)驅(qū)動(dòng)決策的時(shí)代,預(yù)測(cè)分析作為挖掘數(shù)據(jù)潛在價(jià)值的核心手段,正被廣泛 ...
2025-07-10數(shù)據(jù)查詢結(jié)束后:分析師的收尾工作與價(jià)值深化? ? 在數(shù)據(jù)分析的全流程中,“query end”(查詢結(jié)束)并非工作的終點(diǎn),而是將數(shù) ...
2025-07-10CDA 數(shù)據(jù)分析師考試:從報(bào)考到取證的全攻略? 在數(shù)字經(jīng)濟(jì)蓬勃發(fā)展的今天,數(shù)據(jù)分析師已成為各行業(yè)爭(zhēng)搶的核心人才,而 CDA(Certi ...
2025-07-09【CDA干貨】單樣本趨勢(shì)性檢驗(yàn):捕捉數(shù)據(jù)背后的時(shí)間軌跡? 在數(shù)據(jù)分析的版圖中,單樣本趨勢(shì)性檢驗(yàn)如同一位耐心的偵探,專注于從單 ...
2025-07-09year_month數(shù)據(jù)類型:時(shí)間維度的精準(zhǔn)切片? ? 在數(shù)據(jù)的世界里,時(shí)間是最不可或缺的維度之一,而year_month數(shù)據(jù)類型就像一把精準(zhǔn) ...
2025-07-09CDA 備考干貨:Python 在數(shù)據(jù)分析中的核心應(yīng)用與實(shí)戰(zhàn)技巧? ? 在 CDA 數(shù)據(jù)分析師認(rèn)證考試中,Python 作為數(shù)據(jù)處理與分析的核心 ...
2025-07-08SPSS 中的 Mann-Kendall 檢驗(yàn):數(shù)據(jù)趨勢(shì)與突變分析的有力工具? ? ? 在數(shù)據(jù)分析的廣袤領(lǐng)域中,準(zhǔn)確捕捉數(shù)據(jù)的趨勢(shì)變化以及識(shí)別 ...
2025-07-08備戰(zhàn) CDA 數(shù)據(jù)分析師考試:需要多久?如何規(guī)劃? CDA(Certified Data Analyst)數(shù)據(jù)分析師認(rèn)證作為國(guó)內(nèi)權(quán)威的數(shù)據(jù)分析能力認(rèn)證 ...
2025-07-08LSTM 輸出不確定的成因、影響與應(yīng)對(duì)策略? 長(zhǎng)短期記憶網(wǎng)絡(luò)(LSTM)作為循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)的一種變體,憑借獨(dú)特的門(mén)控機(jī)制,在 ...
2025-07-07統(tǒng)計(jì)學(xué)方法在市場(chǎng)調(diào)研數(shù)據(jù)中的深度應(yīng)用? 市場(chǎng)調(diào)研是企業(yè)洞察市場(chǎng)動(dòng)態(tài)、了解消費(fèi)者需求的重要途徑,而統(tǒng)計(jì)學(xué)方法則是市場(chǎng)調(diào)研數(shù) ...
2025-07-07CDA數(shù)據(jù)分析師證書(shū)考試全攻略? 在數(shù)字化浪潮席卷全球的當(dāng)下,數(shù)據(jù)已成為企業(yè)決策、行業(yè)發(fā)展的核心驅(qū)動(dòng)力,數(shù)據(jù)分析師也因此成為 ...
2025-07-07剖析 CDA 數(shù)據(jù)分析師考試題型:解鎖高效備考與答題策略? CDA(Certified Data Analyst)數(shù)據(jù)分析師考試作為衡量數(shù)據(jù)專業(yè)能力的 ...
2025-07-04SQL Server 字符串截取轉(zhuǎn)日期:解鎖數(shù)據(jù)處理的關(guān)鍵技能? 在數(shù)據(jù)處理與分析工作中,數(shù)據(jù)格式的規(guī)范性是保證后續(xù)分析準(zhǔn)確性的基礎(chǔ) ...
2025-07-04CDA 數(shù)據(jù)分析師視角:從數(shù)據(jù)迷霧中探尋商業(yè)真相? 在數(shù)字化浪潮席卷全球的今天,數(shù)據(jù)已成為企業(yè)決策的核心驅(qū)動(dòng)力,CDA(Certifie ...
2025-07-04CDA 數(shù)據(jù)分析師:開(kāi)啟數(shù)據(jù)職業(yè)發(fā)展新征程? ? 在數(shù)據(jù)成為核心生產(chǎn)要素的今天,數(shù)據(jù)分析師的職業(yè)價(jià)值愈發(fā)凸顯。CDA(Certified D ...
2025-07-03