
本系列文章主要介紹機器學習在實踐中的應用,介紹利用 python 的生態環境,使用機器學習的算法來解決工程實踐中的問題,而不是介紹算法本身。本系列文章參考了《機器學習Python實踐》,會通過例子一步一步地引導大家使用機器學習來處理和分類與回歸模型相關的問題。每個算法模型都介紹其較為通用且實用的建模過程,力爭使基礎較差的讀者也能無障礙利用python來使用機器學習算法。
1 初識機器學習
1.1 什么是機器學習?
機器學習(Machine Leaming , ML)是一門多領域的交叉學科,涉及概率論、統計學、線性代數、算法等多門學科。 它專門研究計算機如何模擬和學習人的行為,以獲取新的知識或技能,重新組織已有的知識結構使之不斷完善自身的性能。
機器學習已經有了十分廣泛的應用,例如:數據挖掘、計算機視覺、自然語言處理、生物特征識別、搜索引擎、醫學診斷、檢測信用卡欺詐、證券市場分析、 DNA 序列測序、語音和手寫識別、戰略游戲和機器人運用。
監督學習即在機器學習過程中提供對錯指示。一般是在數據組中包含最終結果(0 , 1),通過算法讓機器自己減少誤差。這一類學習主要應用于分類和預測(Regression &Classify) 。監督學習從給定的訓練數據集中學習出一個目標函數,當新的數據到來時,可以根據這個函數預測結果。監督學習的訓練集要求包括輸入和輸出,也可以說包括特征和目標,訓練集中的目標是由人標注的。常見的監督學習算法包括回歸分析和統計分類。非監督學習又稱歸納性學習(Clustering),利用 K 方式(KMean)建立中心( Centriole),通過循環和遞減運算(lteration&Descent)來減小誤差,達到分類的目的 。
機器學習解決的問題:分類,回歸,降維,聚類。其中有些算法適合多種問題,有些只適合解決一種問題,下面列出一些常見的一些機器學習算法。
1.2 學習機器學習的誤區
在學習機器學習之前,有一些理解和誤區需要先做好說明,防止大家在學習機器學習的過程中過于鉆牛角尖。對于通過Python來基本實現機器學習算法,有幾個誤區可能是比較廣泛存在的,應該盡量避免:
1、必須非常熟悉Python的語法和擅長Python的編程。實際上并不需要,Python有scikit-learn模塊等可以直接進行建模的調用包,基本只需要學會python的各種基礎的知識和應用,熟悉scikit-learn的相關模型用法,以及包括numpy、pandas、matplotlib模塊在內的常用的數據處理和可視化包,就可以實現各種機器學習算法了。
2、必須非常深入地學習和理解在scikit- learn中使用的機器學習的理論和算法。實際上也不需要,除非你是這一方向的碩士甚至博士學位的學習者。機器學習不同的算法涉及的知識點是非常廣闊的,要做到每一種算法的理論知識的學習都非常深入,是比較難的,實際上簡單的機器學習應用中,只需要了解不同算法的基礎知識就可以使用了。
3、學習知識就行了,不需要做什么項目。恰恰相反,機器學習的應用是需要大量的項目經驗積累,才能把機器學習用得更好。
這些方式對一部分人可能會非常有效,但是這會降低掌握機器學習技能的速度和要達到通過機器學習來解決問題的目標。這也會浪費大量時間單獨學習機器學習算法,但卻不知如何利用機器學習來解決現實中遇到的問題。 實際上利用Python來實現機器學習算法的門檻并不高,在基本運用過程中,只需要了解機器學習各種算法的一些基礎知識,一些常用流程和不同算法,數據集的適用要求就可以了。
1.3 Python 中的機器學習
本系列文章主要關注監督學習中的分類與回歸問題處理的預測模型,這是在工業中應用非常廣泛的分類,也是scikit-leam擅長的一個領域。與統計學不同,機器學習的預測模型是用來理解數據、解決問題的;聚焦于如何創建一個更加精準的模型,而不是用來解釋模型是如何設置的。與大部分機器學習的領域不同的是,預測模型是使用表格格式的數據作為模型的輸入的,因此數據的采集和整理是很重要的工作。
在接下來的一系列文章中,致力于讓大家能夠學習在項目中如何將機器學習的任務和Python有機地結合在一起,以便實現每一個機器學習問題的最佳實踐。通過各種實例來理解學到的預測模型的知識。盡量完善一套較為通用的機器學習建模過程,通過python的一系列方法,力求只是進行簡單的復制粘貼操作就可以啟動一個新的機器學習項目。
我們將通過項目來介紹基于Python的生態環境如何完成機器學習的相關工作。一旦明白了如何使用Python平臺來完成機器學習的任務,就可以在不同的項目中重復使用這種方法解決問題。利用機器學習的預測模型來解決問題共有六個基本步驟。
1.4 學習機器學習的原則和技巧
學習機器學習是一段旅程。需要知道自己具備的技能、目前所掌握的知識,以及明確要達到的目標。要實現自己的目標需要付出時間和辛勤的工作 ,但是在目標的實現過程中 ,有很多工具可以幫助你快速達成目標。
1、創建半正式的工作產品。以博客文章、技術報告和代碼存儲的形式記下學習和發現的內容,快速地為自己和他人提供一系列可以展示的技能、知識及反思。
2、實時學習。不能僅在需要的時候才學習復雜的主題,例如,應該實時學習足夠的概率和線性代數的知識來幫助理解正在處理的算法。在開始進入機器學習領域之前,不需要花費太多的時間來專門學習統計和數學方面的知識,而是要在平時的使用和參與過程中不斷地進行實時學習,積累知識。
3、利用現有的技能。如果可以編碼,那么通過實現算法來理解它們,而不是研究數學理論。使用自己熟悉的編程語言,讓自己專注于正在學習的一件事情上,不要同時學習一種新的語言、工具或類庫,這樣會使學習過程復雜化。 掌握是理想。掌握機器學習需要持續不斷的學習。也許你永遠不可能實現掌握機器學習的目標,只能持續不斷地學習和改進所掌握的知識。
下面三個技巧可以有效地幫助你快速提高學習機器學習的能力。
1.5 總結
這一系列的文章主要是寫給對機器學習感興趣和立志學習機器學習,但只有機器學習基礎知識的甚至沒多少了解人群,主要是介紹關于機器學習實踐的內容,而不是關于機器學習的理論知識。 這里只會簡單介紹機器學習的基本原理和算法。在這里假設你已經掌握了機器學習的基礎知識,或者有能力自己來完成機器學習的基礎知識的學習。
有一些人可能只是對機器學習的理論知識比較了解,但是沒有多少項目實踐應用,對于機器學習的應用實踐可能不怎么了解;有一些人則可能只是對機器學習有一個大概的了解,不知道能通過什么樣的工具和方法來使用,該如何使用。而在本系列文章中,將會引導讀者如何通過Python實踐機器學習算法。
2 Python機器學習的生態圈
隨著 Python 生態圈的發展,在機器學習領域,Python 已經發展成為機器學習方面最主要的語言。Python 為什么能夠成為機器學習的主流語言?這是因為 Python 不僅可以應用在R&D科研部門,也可以應用在實際的生產當中。本段將主要介紹Python在機器學習方面的生態圈。
2.1 Python
Python是一門面向對象的動態解釋語言,簡單易學,并且具有很好的可讀性。Python語法簡潔清晰,特色之一是強制用空白符(White Space)作為語句縮進。Python 具有豐富和強大的類庫,它常被稱為“膠水語言”,能夠很輕松地把用其他語言制作的各種模塊(尤其是C/C++)聯結在一起。常見的一種應用情形是,先使用 Python 快速生成程序的原型(有時甚至是程序的最終界面),然后對其中有特別要求的部分用更合適的語言改寫, 比如 3D游戲對圖形渲染模塊的性能要求特別高,就可以用 C/C++重寫,而后封裝為 Python可以調用的擴展類庫。目前,在 Python 的生態圈中存在大量的第三方擴展類庫,可以借助這些類庫輕松實現項目需求。需要注意的是,在使用擴展類庫時可能需要考慮平臺問題,某些擴展類庫可能不提供跨平臺的實現。Python 目前是一門非常流行的語言,在 TIOBE最新推出的2020年1月編程語言排名位列第三,用戶使用率穩居前三。
在PYPL各種編程語言的流行程度的統計中,最新一期2020年1月Python的排名遙遙領先。
Python 是一門動態語言,非常適合于交互性開發和大型項目的快速原型開發。由于Python 具有豐富的類庫支持,因此被廣泛應用于機器學習和數據科學方面。從這個方面來說,利用 Python 可以將研究項目和生產項目用統一的語言來實現,這就有效地降低了將研究項目轉化成生產項目的成本。
2.2 SciPy
SciPy 是在數學運算、科學和工程學方面被廣泛應用的Python 類庫。它包括統計、優化、整合、線性代數模塊、傅里葉變換、信號和圖像處理、常微分方程求解器等,因此被廣泛地應用在機器學習項目中 。 SciPy 依賴以下幾個與機器學習相關的類庫。
NumPy:是 Python 的一種開源數值計算擴展。它可用來存儲和處理大型矩陣,提供了許多高級的數值編程工具, 如矩陣數據類型、矢量處理、精密的運算庫。
Pandas:是基于 NumPy 的一種工具,是為了解決數據分析任務而創建的 。 Pandas 納入了大量庫和一些標準的數據模型,提供了高效地操作大型數據集所需的工具,也提供了大量能使我們快速、便捷地處理數據的函數和方法 。
Matplotlib:Python中最著名的20繪圖庫,十分適合交互式地進行制圖;也可以方便地將它作為繪圖控件,嵌入GUI應用程序中 。
熟悉 SciPy 是提高機器學習實踐的有效手段,尤其是在以下幾個方面:
2.3 scikit-learn
scikit-leam是Python中開發和實踐機器學習的著名類庫之一,依賴于SciPy及其相關類庫來運行。scikit-leam的基本功能主要分為六大部分:分類、回歸、聚類、數據降維、模型選擇和數據預處理。需要指出的是,由于scikit-leam本身不支持深度學習,也不支持GPU加速,因此 scikit-leam對于多層感知器(MLP)神經網絡的實現并不適合處理大規模問題。(scikit-leam對MLP 的支持在 0.18 版之后增加)
scikit-leam是一個開源項目,遵守BSD協議,可以將項目應用于商業開發。目前主要由社區成員自發進行維護??赡苁怯捎诰S護成本的限制,scikit-leam相比其他項目要顯得更為保守,這主要體現在兩個方面 :
比方說,神經網絡不見得比決策樹好,同樣反過來也不成立。最后的結果是有很多因素在起作用的,比方說數據集的大小以及組成。
所以,針對你要解決的問題,最好是嘗試多種不同的算法。并借一個測試集來評估不同算法之間的表現,最后選出一個結果最好的。當然,你要選適合解決你問題的算法來嘗試。比方說,要打掃房子,你會用真空吸塵器,掃把,拖把;你絕對不會翻出一把鏟子來開始挖坑,對吧。
面對海量的機器學習算法,萌新最愛問的是:“我該選什么算法?” 在回答這個問題之前,要先想清楚:
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
在本文中,我們將探討 AI 為何能夠加速數據分析、如何在每個步驟中實現數據分析自動化以及使用哪些工具。 數據分析中的AI是什么 ...
2025-05-20當數據遇見人生:我的第一個分析項目 記得三年前接手第一個數據分析項目時,我面對Excel里密密麻麻的銷售數據手足無措。那些跳動 ...
2025-05-20在數字化運營的時代,企業每天都在產生海量數據:用戶點擊行為、商品銷售記錄、廣告投放反饋…… 這些數據就像散落的拼圖,而相 ...
2025-05-19在當今數字化營銷時代,小紅書作為國內領先的社交電商平臺,其銷售數據蘊含著巨大的商業價值。通過對小紅書銷售數據的深入分析, ...
2025-05-16Excel作為最常用的數據分析工具,有沒有什么工具可以幫助我們快速地使用excel表格,只要輕松幾步甚至輸入幾項指令就能搞定呢? ...
2025-05-15數據,如同無形的燃料,驅動著現代社會的運轉。從全球互聯網用戶每天產生的2.5億TB數據,到制造業的傳感器、金融交易 ...
2025-05-15大數據是什么_數據分析師培訓 其實,現在的大數據指的并不僅僅是海量數據,更準確而言是對大數據分析的方法。傳統的數 ...
2025-05-14CDA持證人簡介: 萬木,CDA L1持證人,某電商中廠BI工程師 ,5年數據經驗1年BI內訓師,高級數據分析師,擁有豐富的行業經驗。 ...
2025-05-13CDA持證人簡介: 王明月 ,CDA 數據分析師二級持證人,2年數據產品工作經驗,管理學博士在讀。 學習入口:https://edu.cda.cn/g ...
2025-05-12CDA持證人簡介: 楊貞璽 ,CDA一級持證人,鄭州大學情報學碩士研究生,某上市公司數據分析師。 學習入口:https://edu.cda.cn/g ...
2025-05-09CDA持證人簡介 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度、美團、阿里等 ...
2025-05-07相信很多做數據分析的小伙伴,都接到過一些高階的數據分析需求,實現的過程需要用到一些數據獲取,數據清洗轉換,建模方法等,這 ...
2025-05-06以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda.cn/g ...
2025-04-30CDA持證人簡介: 邱立峰 CDA 數據分析師二級持證人,數字化轉型專家,數據治理專家,高級數據分析師,擁有豐富的行業經驗。 ...
2025-04-29CDA持證人簡介: 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度,美團,阿里等 ...
2025-04-28CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-27數據分析在當今信息時代發揮著重要作用。單因素方差分析(One-Way ANOVA)是一種關鍵的統計方法,用于比較三個或更多獨立樣本組 ...
2025-04-25CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-25在當今數字化時代,數據分析師的重要性與日俱增。但許多人在踏上這條職業道路時,往往充滿疑惑: 如何成為一名數據分析師?成為 ...
2025-04-24以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《劉靜:10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda ...
2025-04-23