python數(shù)據(jù)分析課件_第1頁(yè)
python數(shù)據(jù)分析課件_第2頁(yè)
python數(shù)據(jù)分析課件_第3頁(yè)
python數(shù)據(jù)分析課件_第4頁(yè)
python數(shù)據(jù)分析課件_第5頁(yè)
已閱讀5頁(yè),還剩42頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

python數(shù)據(jù)分析(DOC46頁(yè))

幾年后發(fā)生了。在使用SAS工作超過(guò)5年后,我決定走出自己的舒服

區(qū)。作為一個(gè)數(shù)據(jù)科學(xué)家,我查找其他有用的工具的旅程開(kāi)始了!幸運(yùn)

的是,沒(méi)過(guò)多久我就決定,Python作為我的開(kāi)胃菜。

我總是有一個(gè)編寫(xiě)代碼的傾向。這次我做的是我真正喜愛(ài)的。代碼。

原先,寫(xiě)代碼是如此容易!

我一周內(nèi)學(xué)會(huì)了Python基礎(chǔ)。同時(shí),從那時(shí)起,我不僅深度探究了

這門語(yǔ)言,而且也關(guān)心了許多人學(xué)習(xí)這門語(yǔ)言。Python是一種通用語(yǔ)

言。然而,多年來(lái),具有強(qiáng)大的社區(qū)支持,這一語(yǔ)言差不多有了專門的

數(shù)據(jù)分析和推測(cè)模型庫(kù)。

由于Python缺乏數(shù)據(jù)科學(xué)的資源,我決定寫(xiě)這篇教程來(lái)關(guān)心別人更

快地學(xué)習(xí)在本教程中,我們將講授一點(diǎn)關(guān)于如何使用

PythonoPython

進(jìn)行數(shù)據(jù)分析的信息,咀嚼它,直到我們覺(jué)得舒服并能夠自己去實(shí)踐。

名目

1.數(shù)據(jù)分析的Python基礎(chǔ)

。什么緣故學(xué)Python用來(lái)數(shù)據(jù)分析

oPython2.7v/s3.4

。如何樣安裝Python

O在Python上運(yùn)行一些簡(jiǎn)單程序

2.Python的庫(kù)和數(shù)據(jù)結(jié)構(gòu)

。Python的數(shù)據(jù)結(jié)構(gòu)

。Python的迭代和條件結(jié)構(gòu)

oPython庫(kù)

3.在Python中使用Pandas進(jìn)行探干脆分析

。序列和數(shù)據(jù)框的簡(jiǎn)介

。分析Vidhya數(shù)據(jù)集——貸款的推測(cè)問(wèn)題

4.在Python中使用Pandas進(jìn)行數(shù)據(jù)再加工

5.使用Python中建立推測(cè)模型

。邏輯回來(lái)

o決策樹(shù)

O隨機(jī)森林

讓我們開(kāi)始吧

L數(shù)據(jù)分析的Python基礎(chǔ)

什么緣故學(xué)Python用來(lái)數(shù)據(jù)分析

專門多人都有愛(ài)好選擇Python作為數(shù)據(jù)分析語(yǔ)言。這一段時(shí)刻以來(lái),

我有比較過(guò)SAS和R。那個(gè)地點(diǎn)有一些緣故來(lái)支持學(xué)習(xí)Python:

?開(kāi)源——免費(fèi)安裝

?極好的在線社區(qū)

?專門容易學(xué)習(xí)

?能夠成為一種通用的語(yǔ)言,用于基于Web的分析產(chǎn)品數(shù)據(jù)科學(xué)和生產(chǎn)中。

不用說(shuō),它仍舊有幾個(gè)缺點(diǎn):

?它是一種說(shuō)明性的語(yǔ)言,而不是編譯的語(yǔ)言,因此可能占用更多的CPU時(shí)刻。然而,

由于它節(jié)約了程序員的時(shí)刻〔由于學(xué)習(xí)的方便〕,它可能仍舊是一個(gè)專門好的選擇。

Python2.7v/s3.4

這是關(guān)于Python的一個(gè)最具爭(zhēng)議的話題。你可能總是不能幸免遇到,

專門是假如你是一個(gè)初學(xué)者。那個(gè)地點(diǎn)沒(méi)有正確/錯(cuò)誤的選擇。它完全

取決于具體情形和你的需要。我會(huì)嘗試給你一些建議,以關(guān)心你做出明

智的選擇。

什么緣故選擇Python2.7

1.極好的社區(qū)支持!這是你在初期需要的東西。Python2發(fā)行于2000年末,差不多

被使用超過(guò)15年。

2.專門多第三方庫(kù)!盡管許多庫(kù)差不多提供了3.X的支持,但仍舊有大量的模塊只工

作在2.X。假如你打算將Python用于具體的應(yīng)用,如Web開(kāi)發(fā)這種高度依

靠外部模塊的,你選擇2.7可能會(huì)更好。

3.3.X版本的一些特性有向后兼容性,能夠使用2.7版本。

什么緣故選擇Python3.4

1.更整齊和更快!Python開(kāi)發(fā)者修正了一些固有的問(wèn)題和小缺點(diǎn),以此為以后建立

一個(gè)強(qiáng)大的基礎(chǔ)。這些可能不是專門相關(guān),但最終會(huì)專門重要。

2.這是以后!2.7是2.X族公布的最后一個(gè)版本,同時(shí)最終每個(gè)人都要轉(zhuǎn)移到3.X版

本。Python3在過(guò)去5年差不多公布的穩(wěn)固版本,并將連續(xù)。

沒(méi)有明確的贏家,但我想,底線是,你應(yīng)該用心于學(xué)習(xí)Python語(yǔ)言。

版本之間的轉(zhuǎn)換應(yīng)該只是一個(gè)時(shí)刻問(wèn)題。敬請(qǐng)期待,不久的今后一個(gè)專

門對(duì)比Python2.X和3X的文章!

如何樣安裝Python

有兩種方法安裝Python

?你能夠直截了當(dāng)從項(xiàng)目網(wǎng)站下載Python,然后單獨(dú)安裝你想要的組件和庫(kù)

?或者,你能夠下載并安裝一個(gè)包,它附帶了預(yù)裝的庫(kù)。我建議您下載Anaconda.

另一種選擇是

EnthoughtCanopyExpresso

第二種方法提供了一個(gè)幸免苦惱的安裝,因此我會(huì)舉薦給初學(xué)者。這種

方法是你必須等待整個(gè)包進(jìn)行升級(jí),即使你只是對(duì)一個(gè)單一的庫(kù)的

最新版本感愛(ài)好。它應(yīng)該不重要,直到和除非,直到和除非,你正在做

的尖端統(tǒng)計(jì)研究。

選擇開(kāi)發(fā)環(huán)境

一旦你差不多安裝了Python,選擇環(huán)境能夠有專門多種選擇。那個(gè)

地點(diǎn)是3個(gè)最常見(jiàn)的選擇:

?終端/基于Shell

?IDLE(默認(rèn)環(huán)境)

?iPythonnotebook-----類似于R的markdown

箱Python2.7.6Shell一口Kifl

FileEditShellDebugOptionsWindowsHelp

Python2.7.6(default,Nov102013,19:24:24)[MSCv.150064bit(AMD64)]onwin

32

Type"copyright","credits"or"license()nformoreinformation.

?>I

而環(huán)境權(quán)取決于你的需要,我個(gè)人更喜愛(ài)iPythonnotebook一點(diǎn)。

它提供了許多良好的功能,編寫(xiě)代碼的同時(shí)還能夠用于記錄,你能夠選

擇在上面運(yùn)行代碼塊〔而不是一行一行的執(zhí)行〕。

我們?cè)谡麄€(gè)教程中將使用Ipython環(huán)境

熱身:跑第一個(gè)Python程序

你能夠使用Python作為一個(gè)簡(jiǎn)單的運(yùn)算器來(lái)開(kāi)始:

:JUpyterMyFirstiPythonNotebookLastCheckpoint:3minutesag(

FileEditViewInsertCellKernelHelp

IS+?t個(gè)*H■CMarkdown▼CellToolbarNone

In[1]:2+3ffFirstprograminiPythonnotebookenvironment

^MultiplelinescanbewrittenhereandtheyMILexectec

Out[l]:5

Thisisanexampleofmarkdowntext.Thisisusefulforaddingcommi

有一些情況需要注意:

?你能夠在你的終端/CMD鍵入''IPythonnotebook"來(lái)啟動(dòng)IPythonnotebook,

這取決于你的工作在操作系統(tǒng)

?你能夠通過(guò)簡(jiǎn)單地點(diǎn)擊上面截圖中的名字來(lái)對(duì)IPythonnotebook命名

?界面顯示In[*]代表輸入和Out[*]代表輸出。

?你能夠通過(guò)按''Shift+Enter"或''ALT+Enter”來(lái)執(zhí)行代碼,假如你后面還想插

入一行。

在我們深入挖掘如何解決問(wèn)題之前,讓我們退后一步,了解Python

的差不多知識(shí)。當(dāng)我們明白數(shù)據(jù)結(jié)構(gòu)和迭代和條件結(jié)構(gòu)是形成任何語(yǔ)言

的關(guān)鍵。在Python中,這些包括列表、字符串、元組、字典、for■循

環(huán),while循環(huán),if-else等等,讓我們來(lái)看看下面的因素。

2.在Python上運(yùn)行一些簡(jiǎn)單程序

Python的數(shù)據(jù)結(jié)構(gòu)

以下是Python中使用的一些數(shù)據(jù)結(jié)構(gòu)。你應(yīng)該熟悉他們,以便恰當(dāng)

的使用它們。

?歹11表——列表是在Python中最通用的數(shù)據(jù)結(jié)構(gòu)。列表能夠如此簡(jiǎn)單的定義:確實(shí)

是在方括號(hào)中一系列用逗號(hào)來(lái)分隔的值。列表可能包含不同類型的項(xiàng),但它們通常

都有相同類型的。Python列表是可變的,列表中的單個(gè)元素是能夠改變的。

那個(gè)地點(diǎn)是一個(gè)快速的例子,定義了一個(gè)列表,然后訪問(wèn)它:

Lists

Alistcanbesimplydefinedbywritingcommaseparatedvaluesinsquarebrackets.

In[1]:squares_list=[0,1,4,9,16,25]

In[2]:squares_list

Out[2]:(Or1,4,9,1€,25]

Individualelementsofalistcanbeaccessedbywritingtheindexnumberinsquarebracket.Pleasenotethatthefirstindexofalistis0an

In[3]:squaxe3_list[0]^Indexingreturnstheitem

Out[3]:0

Arangeofscriptcanbeaccessedbyhavingfirstindexandlastindex

In[4]:squares^ist[2:4]^Slicingreturnsanevlist

Out[4]:[4,9]

ANegativeindexaccessesthelistfromend

In[5]:3qpiares_list[-2]shouldreturnthesecondlastelement二二tr.elist

Out[5]:16

Afewcommonmethodsapplicabletolistsinclude:append()extend。insert。remove()pop()count()sort()reverse()

?字符串——字符串能夠簡(jiǎn)單的使用單引號(hào)「〕、雙引號(hào)〔"〕或三引號(hào)〔’’’〕

來(lái)定義。字符串封閉三引號(hào))中能夠跨過(guò)多行的代碼,在文檔字符串中是

專門常用的〔記錄功能的Python方式〕。作為一個(gè)轉(zhuǎn)義字符。請(qǐng)注意,Python中

的字符串是不可變的,因此你不能改變字符串的部分。

Strings

Astringcanbesimplydefinedbyusingsingle(*),double(")ortriple(*)quotation

In[6]:greeting=*Hello1

printgreeting[1]#ReturncharacterontheIndex1

printlen(greeting)#Printslengthofstring

printgreeting+'World'#StringConcatenatlon

e

5

HellcWorld

Rawstringscanbeusedtopassonstringasis.Pythoninterpretterdoesnotalterthestring,ifyouspecifyastringtoberaw.Rawsi

string

In[8]:stmt=r*\nisanewlinecharacterbydefault.,

printstmt

\nisanewlinecharacterbydefault.

Pythonstringsareimmutableandhencecanbechanged.Doingsowillresultinanerror

In[9]:greeting[1:]=1i'^TryingtochangeHellotoHi..Shouldresultinanerror

TypeErrorTraceback(mostrecentcalllast)

<ipython-inpu-C-9-2da872e33998>in<module>()

--->1greeting(1:]=1i*^TryingtochangeHellotoHi.Shouldresultinanerror

TypeError:*str'objectdceanotsupportiremassignment

Commonstringmethodsincludelov/er(),upper(),strip(),isdigit(),isspace(),find(),replace(),split()andjoin().Theseareusuallyvery

manipulationsorcleaningontextfields.

?元組——元組由一系列由逗號(hào)分隔的值表示。元組是不可變的,輸出的用括號(hào)包圍,

目的是嵌套結(jié)構(gòu)能夠被正確處理。此外,盡管元組是不可變的,但它們能夠在必要

是含有可變數(shù)據(jù)。

因?yàn)樵M是不可變的,不可改變的,他們相對(duì)列表來(lái)說(shuō)能夠處理的更

快。因此,假如你的清單是不可能改變的,你應(yīng)該使用元組,而不是列

Tuples

Atupleisrepresentedbyanumberofvaluesseparatedbycommas

In[10]:tuple_exaiEple=。,1,4,9,16,25

In[11]:tuple_exanqple/outputvouldbeenclosedinparanthesis

Out[11]:(0f1,4,9,16,25)

In[12]:tuple_exair.ple[2]fSingleelementscanbeaccessedinsimilarfashion

Out[12]:4

In[13]:tuple_exair.ple[2]=6#Tuplesareimmutableandhencethisshouldresulti

TypeErrorTraceback(mostrecentcalllas

<ipyrhon-input-13-6c410e816018>in<module>()

------->1tuple_exainple[2]=6#Tuplesareimmutableandhencethisshould

TypeError:'tuple1objectdoesnotsupportitemassignment

,字典一字典是鍵:值對(duì)一個(gè)無(wú)序集合,要求鍵是唯獨(dú)的〔在一個(gè)字典里〕。一對(duì)

大括號(hào)創(chuàng)建一個(gè)空的字典:{}。

Dictionary

Adictionaryisanunorderedsetofkey:valuepairs,withtherequirementthatthekeysareunique(withinonedictior

In[20]:extensions={1Kxmal':9073,'lavish1:9128,"Sunil1:9223,"Nitin,:93

extensions

0ut[20]:{?Kunal*:9073,"Nitin*:9330,'Sunil':9223,?lavish?:9128)

In[22]:extensions[*Idukesh1]=9150

extensions

Out[22]:{?Kunal1:9073,?Mukesh1:9150,?Nitin,:9330,'Sunil,:9223,'lavish*:91

In[23]:extensions.keys

Out[23]:['Sunil',?lavish*,?Kunal',?Mukesh*,'Nitin*]

Python的迭代和條件結(jié)構(gòu)

和大多數(shù)語(yǔ)言一樣,Python也有一個(gè)FOR循環(huán),這是最廣泛使用的

迭代方法。它有一個(gè)簡(jiǎn)單的語(yǔ)法:

foriin[PythonIterable]:

expression(i)

那個(gè)地點(diǎn)的''Python的迭代能夠是列表、元組或其他先進(jìn)的數(shù)據(jù)結(jié)

構(gòu),我們將在后面的章節(jié)中探討。讓我們來(lái)看看一個(gè)簡(jiǎn)單的例子,確定

一個(gè)數(shù)字的因子。

fact=l

foriinrange(l,N+l):

fact*=i

來(lái)看看條件語(yǔ)句,它們是用來(lái)基于條件執(zhí)行代碼片段。最常用的結(jié)構(gòu)

是if-else,有以下語(yǔ)法:

if[condition]:

_executioniftrue_

else:

_executioniffalse_

例如,假如我們想打印出某個(gè)數(shù)字n是偶數(shù)依舊奇數(shù):

if==0:

print*Even,

else:

print'Odd*

既然你熟悉了Python的基礎(chǔ),我們來(lái)更近一步。假如你像完成以下

任務(wù):

1.乘2矩陣

2.求二次方程的根

3.繪制條形圖和直方圖

4.建立統(tǒng)計(jì)模型

5.訪問(wèn)網(wǎng)頁(yè)

假如你想從零開(kāi)始寫(xiě)代碼,它將是一場(chǎng)噩夢(mèng),你使用Python可不能

超過(guò)2天!但不要擔(dān)憂這些。值得慶幸的是,有許多預(yù)定義的庫(kù),我們

能夠直截了當(dāng)導(dǎo)入到我們的代碼,使我們的生活專門容易。

例如,考慮我們剛才看到的因子的例子。我們能夠一步就完成:

math.factorial(N)

因此,為了如此我們需要導(dǎo)入的math庫(kù)。讓我們探究下一個(gè)不同的

庫(kù)。

Python庫(kù)

在開(kāi)始我們的學(xué)習(xí)Python之旅之前,讓我們先一步,了解一些有用

的python庫(kù)。第一步明顯是要學(xué)會(huì)將它們導(dǎo)入到我們的環(huán)境中。在

Python中有以下幾種方法:

importmathasm

frommathimport*

在第一種方式中,我們差不多為math庫(kù)定義了一個(gè)別名mo現(xiàn)在我

們能夠使用數(shù)學(xué)庫(kù)的各種功能〔例如階乘,通過(guò)引用別名

m.factorialO)。

第二方式,你需要導(dǎo)入math的整個(gè)命名空間,你能夠直截了當(dāng)使用

factorial(),而不用提到matho

提示:谷歌舉薦您使用第一種方式導(dǎo)入庫(kù),因?yàn)槟鷮⒚靼缀瘮?shù)來(lái)自何逅

下面是一個(gè)庫(kù)列表,你將在任何科學(xué)運(yùn)算和數(shù)據(jù)分析中用到:

?NumPy代表數(shù)值Python.NumPy最強(qiáng)大的功能是n維數(shù)組。該庫(kù)還包含差不多

的線性代數(shù)函數(shù),傅里葉變換,高級(jí)的隨機(jī)數(shù)功能,以及集成其他低級(jí)語(yǔ)言如

Fortran,C和C++的工具。

?SciPy代表科學(xué)的Python.SciPy是基于NumPy的。它是最有用的庫(kù)之一,具有

各種高層次的科學(xué)和工程模塊,如離散傅立葉變換,線性代數(shù),優(yōu)化和稀疏矩陣。

?Matplotlib用于繪制各種各樣的圖表,從直方圖到線圖,再到熱圖。你能夠在

IPythonnotebook中使用PyLab[IPythonnotebook-PyLab=inline)以此使

用這些繪圖功能的inline。假如你忽略inline選項(xiàng),PyLab會(huì)將IPythonnotebook

環(huán)境轉(zhuǎn)換成類似于Matlab的環(huán)境。你也能夠使用Latex命令將math庫(kù)添加到您

的繪圖中。

?Pandas關(guān)于結(jié)構(gòu)化數(shù)據(jù)操作和操縱。它廣泛用于數(shù)據(jù)再加工和數(shù)據(jù)預(yù)備。Pandas

說(shuō)最近一直在推動(dòng)對(duì)PythonPython的使用數(shù)據(jù)科學(xué)家共同體的工具。

?ScikitLearn機(jī)器學(xué)習(xí)庫(kù)。建立在NumPy、SciPy和matplotlib的基礎(chǔ)上,那個(gè)

庫(kù)包含了機(jī)器學(xué)習(xí)和統(tǒng)計(jì)模型包括分類、回來(lái)、聚類和降維等專門多有效的工具。

?Statsmodels用于統(tǒng)計(jì)建模。statsmodels是一個(gè)Python模塊,承諾用戶探究數(shù)

據(jù),估量統(tǒng)計(jì)模型,并進(jìn)行統(tǒng)計(jì)檢驗(yàn)。一個(gè)廣泛的描述性統(tǒng)計(jì),統(tǒng)計(jì)檢驗(yàn)的列表。

繪圖功能,和結(jié)果統(tǒng)計(jì)可用于不同類型的數(shù)據(jù)和每個(gè)估量。

?Seaborn用于統(tǒng)計(jì)數(shù)據(jù)的可視化。Seaborn是Python中用來(lái)繪制讓人喜愛(ài)的并能

提供大量信息的統(tǒng)計(jì)圖形庫(kù)。它是基于matplotlib.Seaborn旨在使可視化成為探

究和明白得數(shù)據(jù)的核心部分。

?Bokeh創(chuàng)建交互式圖、外表盤和現(xiàn)代Web掃瞄器上的數(shù)據(jù)應(yīng)用。它承諾用戶生成

的文雅和簡(jiǎn)潔的d3.js風(fēng)格的圖形。此外,在專門大的或流媒體數(shù)據(jù)集上,它具有

高性能的交互性的能力。

?Blaze擴(kuò)展NumPy和Pandas的分布式和流媒體數(shù)據(jù)集。它能夠用來(lái)訪問(wèn)來(lái)自多

種來(lái)源的數(shù)據(jù),包括bcolz,MongoDB,SQLAIchemy,ApacheSpark,PyTables

等等,結(jié)合Bokeh,Blaze能夠作為一個(gè)專門強(qiáng)大的工具,用于對(duì)大規(guī)模數(shù)據(jù)創(chuàng)建

高效的的可視化和外表板。

?Scrapy用于網(wǎng)絡(luò)爬蟲(chóng)。它是用于獵取特定數(shù)據(jù)模式的一個(gè)專門有用的框架它能

夠通過(guò)開(kāi)始的一個(gè)網(wǎng)站主頁(yè)的網(wǎng)址,然后通過(guò)挖掘網(wǎng)頁(yè)內(nèi)的網(wǎng)站收集信息。

?SymPy用于符號(hào)運(yùn)算。它具有廣泛的功能,從差不多的符號(hào)運(yùn)算到微積分,代數(shù),

離散數(shù)學(xué)和量子物理學(xué)。另一個(gè)有用的功能是將運(yùn)算的結(jié)果格式化為L(zhǎng)aTeX碼的能

力。

?Requests用于訪問(wèn)網(wǎng)絡(luò)。它的工作原理類似于Python標(biāo)準(zhǔn)庫(kù)urllib2,然而更容

易編碼。但關(guān)于初學(xué)者,你會(huì)發(fā)覺(jué)和urllib2細(xì)微的差別,Requests可能更方便。

其它的庫(kù),你可能需要:

?os用于操作系統(tǒng)文件操作

?networkx和igraph基于數(shù)據(jù)操作繪制圖形

?regularexpressions用于在文本數(shù)據(jù)中查找模式

?BeautifulSoup將探究Web,它不如Scrapy,它一次運(yùn)行將從一個(gè)單一的網(wǎng)頁(yè)中

提取信息。

現(xiàn)在我們差不多熟悉Python的基礎(chǔ)和更多的庫(kù),讓我們深入到通過(guò)

Python解決問(wèn)題。是的,我的意思是做一個(gè)推測(cè)模型!在那個(gè)過(guò)程中,

我們使用了一些強(qiáng)大的庫(kù),也遇到了下一級(jí)的數(shù)據(jù)結(jié)構(gòu)。我們將帶你通

過(guò)這3個(gè)關(guān)鍵時(shí)期:

1.數(shù)據(jù)探究一從我們所擁有的數(shù)據(jù)中發(fā)覺(jué)更多

2.數(shù)據(jù)修改一清理數(shù)據(jù)和并修改它使它更適合用來(lái)統(tǒng)計(jì)建模

3.推測(cè)建模一運(yùn)行的實(shí)際算法,自得其樂(lè)

3.在Python中使用Pandas迸行探干脆分析

為了進(jìn)一步探究我們的數(shù)據(jù),讓我把你介紹給另一種動(dòng)物〔看起來(lái)

Python是不夠的!)—Pandas

Pandas是Python最有用的一種數(shù)據(jù)分析庫(kù)的我明白這些名字聽(tīng)起

來(lái)專門驚奇,但堅(jiān)持下去!〕它們關(guān)于增加一直在增加Python在數(shù)據(jù)

科學(xué)界的使用量起了專門大的作用。我們現(xiàn)在將使用Pandas從

AnalyticsVidhya的競(jìng)賽中讀數(shù)據(jù)集,進(jìn)行探干脆分析,建立我們的第

一個(gè)差不多分類算法來(lái)解決這一問(wèn)題。

在加載數(shù)據(jù)之前,讓我們了解Pandas中的2個(gè)關(guān)鍵的數(shù)據(jù)結(jié)構(gòu)

序列和數(shù)據(jù)框

序列和數(shù)據(jù)框的簡(jiǎn)介

序列能夠被明白得為一個(gè)1維標(biāo)記/索引數(shù)組。你能夠通過(guò)這些標(biāo)簽

訪問(wèn)那個(gè)序列的各個(gè)元素。

一個(gè)數(shù)據(jù)框類似于Excel工作簿-你能夠使用列名來(lái)引用列,能夠通過(guò)

行號(hào)來(lái)訪問(wèn)行數(shù)據(jù),本質(zhì)的區(qū)別是,在數(shù)據(jù)幀中,列名和行號(hào)是列和行

的索引。

More:10MinutestoPandas

實(shí)踐數(shù)據(jù)集—貸款推測(cè)問(wèn)題

您能夠從那個(gè)地點(diǎn)下載數(shù)據(jù)集。那個(gè)地點(diǎn)是變量的描述:

VARIABLEDESCRIPTIONS:

VariableDescription

Loan_IDUniqueLoanID

GenderMale/Female

MarriedApplicantmarried(Y/N)

DependentsNumberofdependents

EducationApplicantEducation(Graduate/UnderGraduate)

Self_EmployedSelfemployed(Y/N)

ApplicantincomeApplicantincome

CoapplicantIncomeCoapplicantincome

1,.LoanAmountLoanamountinthousands

iLoan_Amount_TermTermofloaninmonths

1Credit_Historycredithistorymeetsguidelines

IProperty_AreaUrban/SemiUrban/Rural

■Loan_StatusLoanapproved(Y/N)

讓我們從數(shù)據(jù)探究開(kāi)始

開(kāi)始,通過(guò)在你的你的終端/Windows命令提示符鍵入下面的代碼,

來(lái)以InlinePylab模式啟動(dòng)IPython界面:

ipythonnotebook--pylab=inline

這在PyLab環(huán)境下打開(kāi)IPythonnotebook,其中有幾個(gè)有用的庫(kù)差

不多導(dǎo)入。此外,你將能夠繪制您的數(shù)據(jù)內(nèi)聯(lián),這關(guān)于互動(dòng)的數(shù)據(jù)分析

是一個(gè)專門好的環(huán)境。你能夠通過(guò)鍵入以下命令,檢查環(huán)境是否正確的

加載了〔并獲得如以下圖所示的輸出〕:

plot(arange(5))

我目前在Linux上工作,并已將數(shù)據(jù)集儲(chǔ)備在以下位置:

/home/kunal/Downloads/Loan_Prediction/train.csv

導(dǎo)入庫(kù)和數(shù)據(jù)集:

下面是我們將在本教程中使用的庫(kù):

?numpy

?matplotlib

?pandas

請(qǐng)注意,你不需要導(dǎo)入matplotlib和NumPy,因?yàn)槭窃赑yLab環(huán)

境下。但我仍舊在代碼中保留了它們,以防你在不同的環(huán)境中使用代碼。

導(dǎo)入庫(kù)以后,你能夠使用read_csv()函數(shù)讀數(shù)據(jù)集。這是直到那個(gè)時(shí)

期的代碼:

importpandasaspd

importnumpyasnp

importmatplotlibaspit

df=pd.read_csv(M/home/kunal/Downloads/Loan_Prediction/train.csvM)#Reading

thedatasetinadatafnameusingPandas

快速數(shù)據(jù)探究

一旦你讀取了數(shù)據(jù),能夠通過(guò)使用head。函數(shù)查看一下前幾行的數(shù)

據(jù):

df.head(10)

In(3]:df.head(10)^Printingfirst10rowsofdataset

Out[3]:Loan-lDGenderMarriedDependentsEducationSelf-EmployedApplicantincomeCo;

0LP001002MaleNo0GraduateNo58490

1LP001003MaleYes1GraduateNo458315C

2LP001005Male0GraduateYes30000

Not

3LP001006MaleYes0No2583235

Graduate

4LP001008MaleNo0GraduateNo60000

5LP001011MaleYes2GraduateYes541741S

Not

6LP001013MaleYes0No2333151

Graduate

7LP001014Male3+GraduateNo303625C

8LP001018MateYes2GraduateNo4006152

9LP001020Male一.1GraduateNo1284110S

這應(yīng)該打印10行?;蛘?,您也能夠通過(guò)打印數(shù)據(jù)集來(lái)查看更多的行。

接下來(lái),你能夠使用describe。函數(shù)來(lái)查看數(shù)值字段的概要:

df.describe()

In[4]:df.describe()#6etsummaryofnumericaLvariabLe^

Out[4]:ApplicantincomeCoapplicantincomeLoanAmountLoan_Amount_Term

count614.000000614000000592.000000600.00000

mean5403.4592831621.245798146.412162342.00000

std6109.0416732926.24836985,58732565,12041

min150.0000000.0000009.00000012,00000

25%2877.5000000.000000100.000000360.00000

50%3812.5000001188.500000128.000000360.00000

75%57950000002297.25000016800000036000000

max81000.00000041667.000000700.000000480.00000

describe。功能將提供計(jì)數(shù)、平均、標(biāo)準(zhǔn)差〔STD〕,最小值,分位

數(shù)值和最大值〔讀這篇文章來(lái)更新差不多統(tǒng)計(jì)數(shù)據(jù)了解人口分布〕

那個(gè)地點(diǎn)有幾個(gè)結(jié)論,你能夠通過(guò)查看describe。函數(shù)的輸出得出:

1.LoanAmount有(614-592)22個(gè)缺失值

2.Loan_Amount_Term有(614-600)14個(gè)缺失值

3.Credit_HistoryW(614-564)50個(gè)缺失值

4.我們還能夠看到84%的申請(qǐng)者有credit_history,如何樣,credit_history的均值

為0.84〔記住,credit_history將那些有信用歷史的值設(shè)置為1,沒(méi)有的設(shè)置為0]

5.Applicantincome的分布看起來(lái)和expectation呈線性關(guān)系,

Coapplicantincome也是。

請(qǐng)注意,我們通過(guò)比較的平均值和中位數(shù),即50%位數(shù),來(lái)得到偏差

的概念。

關(guān)于非數(shù)值〔例如property_area,credit_history等〕,我們能夠

看看頻率分布,了解他們是否有意義。頻率表能夠通過(guò)以下命令打?。?/p>

df[1Property_Area'].value_counts()

同樣地,我們能夠看看信用卡歷史的唯獨(dú)值。注意,dfname

["column_name]是一個(gè)差不多的索引技術(shù),來(lái)訪問(wèn)一個(gè)數(shù)據(jù)框的特

定的列。它也能夠是列的列表。想要了解更多信息,參考上面的

“Pandas10分鐘教程”的資源共享。

分布分析

現(xiàn)在我們熟悉了差不多的數(shù)據(jù)特點(diǎn),讓我們研究不同變量的分布情

形。讓我們從數(shù)字變量開(kāi)始-即applicantincome和LoanAmount

我們通過(guò)繪制applicantincome的直方圖開(kāi)始,使用下面的命令:

df['Property-Area*].value_counts()

在那個(gè)地點(diǎn),我們觀看到,有幾個(gè)極端值。這也是分箱值為50的緣

故,確實(shí)是為了清晰地描述它的分布。

下一步,我們看箱線圖,了解分布。fare的箱圖能夠使用下面代碼繪

制:

df.boxplot(column="Applicantincome')

90000

80000

70000

60000

50000

40000豐

+

30000

20000

100001

0j

Applicantincome

這證實(shí)了大量的離群值/極值的存在。這能夠歸因于社會(huì)上的收入差

距。部分緣故源于如此一個(gè)事實(shí):我們正在查看不同的教育水平的人。

讓我們依照他們所受的教育進(jìn)行分組:

df.boxplot(column=*Applicantincome'by='Education*)

我們能夠看到,研究生和非畢業(yè)生的平均收入之間沒(méi)有實(shí)質(zhì)性的區(qū)

別。然而畢業(yè)生中高收入的人群更多,它們顯現(xiàn)在專門值的點(diǎn)中。

現(xiàn)在,讓我們使用下面的命令看看LoanAmount的直方圖和箱線圖:

再次,有一些專門的值。B月顯,applicantincome和LoanAmount

都需要進(jìn)行一定的數(shù)據(jù)處理。LoanAmount有一些缺失值以及一些專

門的值,而applicantincome有一些專門值,需要更深入的了解。我

們將在立即到來(lái)的部分完成這些。

分類變量的分析

現(xiàn)在我們了解了applicantincome和loanincome的分布,讓我們

了解更多關(guān)于分類變量的細(xì)節(jié)。我們將使用Excel數(shù)據(jù)透視表和交叉制

表的風(fēng)格。例如,讓我們看看基于信用記錄,能夠獲得貸款的可能性。

這能夠在微軟的Excel上使用一個(gè)透視表實(shí)現(xiàn):

PivotTableFields

Choosefieldstoaddtoreport:

Dragfieldsbetweenareasbelow:

TRLTERSIlliCOLUMNS

=ROWS工VALUES

Credit_History▼AverageofLoan_...▼

注:那個(gè)地點(diǎn)的貸款狀況已被編碼,使用1代表yes,而0代表no,

因此,因此均值代表了獲得貸款的概率。

現(xiàn)在我們將看看使用Python產(chǎn)生類似的成效所需要的步驟。請(qǐng)參考

這篇文章,以使用Pandas獲得不同的數(shù)據(jù)操縱技術(shù)。

tempi=df['Credit_History*].value_counts(ascending=True)

temp2=df,pivot_table(values='Loan_Status',index=['Credit_History*],aggfunc

lambdax:x.map({.mean())

print'FrequencyTableforCreditHistory:'

printtempi

print,\nProbilityofgettingloanforeachCreditHistoryclass:

printtemp2

FrequencyTableforCreditHistory:

089

1475

Name:Credit_History,dtype:int64

ProbilityofgettingloanforeachCreditHistoryclass:

Credit_History

0078652

10.795789

Name:Loan_Status,dtype:float64

現(xiàn)在我們能夠觀看到,我們得到一個(gè)像微軟的的

Excelpivot_tableo

這能夠使用matplotlib庫(kù)繪制成條形圖,使用下面的代碼:

importmatplotlib.pyplotaspit

fig=pit.figure(figsize=(8,4))

axl=fig.add_subplot(121)

axl.set_xlabel(*Credit__History*)

axl.set_ylabel(*CountofApplicants')

axl.set_title(MApplicantsbyCredit_HistoryM)

tempi.plot(kind='bar')

ax2=fig.add_subplot(122)

temp2.plot(kind=*bar')

ax2.set_xlabel(*Credit_History')

ax2.set__ylabel(1Probabilityofgettingloan*)

ax2.set_title(MProbabilityofgettingloanbycredithistory1')

ApplicantsbyCreditHistoryloanbycredithistory

7

c。

os

SI-6

o

H306

uU

?205

-10o-£6

d

d(

qD64

jJ

o

O0.。

lo

u3

n2?三

o

oqo

e2

ooq

」6

d1

00

oQo

r-1oi-i

CreditHistoryCreditHistory

這說(shuō)明,假如申請(qǐng)人有一個(gè)有效的信用記錄,獲得貸款的機(jī)會(huì)是沒(méi)有

信用記錄的人的八倍。你能夠依照Married,Self-Employed,

Property_Area等繪制類似的圖。

或著,這兩個(gè)圖能夠進(jìn)行組合以后的可視化,使用堆疊圖表示:

temp3=pd.crosstab(df[*Credit_History*],df[,Loan_Status*])

1

temp3.plot(kind='bar',stacked=True.?color=['red'9blue*],grid=False)

QeditHistoiy

你還能夠再上圖中加入性別變量〔類似于Excel中的數(shù)據(jù)透視表〕

(?H(

B£

E£

B

00

01

U.-)0)

O1

))

Credit_History,Gender

假如你還沒(méi)有意識(shí)到,我們剛剛在那個(gè)地點(diǎn)創(chuàng)建了兩個(gè)差不多的分類

算法,一個(gè)基于信用歷史,而另一個(gè)基于2個(gè)分類變量〔包括性別〕。

你能夠在AVDatahacks上專門快的編寫(xiě)代碼來(lái)創(chuàng)建首次提交。

我們只看到我們?nèi)绾问褂肞ython中的Pandas做探干脆分析。我期

望你對(duì)大熊貓〔動(dòng)物〕的愛(ài)現(xiàn)在增加了——給予一些關(guān)心,那個(gè)庫(kù)能夠

為你提供分析數(shù)據(jù)集。

接下來(lái)讓我們進(jìn)一步探討叩plicantincome和loanstatus變量,進(jìn)

行數(shù)據(jù)修改和創(chuàng)建一個(gè)數(shù)據(jù)集并應(yīng)用各種建模技術(shù)。我強(qiáng)烈要求你采納

另一個(gè)數(shù)據(jù)集和習(xí)題,并在進(jìn)一步閱讀之前完成一個(gè)獨(dú)立的例子。

在Python中使用Pandas進(jìn)行數(shù)據(jù)再加工

4.數(shù)據(jù)修改闔新的需要

關(guān)于那些一直跟下來(lái)的人來(lái)說(shuō),這時(shí)你必須穿上鞋才能開(kāi)始跑。

在我們的探究數(shù)據(jù)期間,我們發(fā)覺(jué)了數(shù)據(jù)集的一些問(wèn)題,在數(shù)據(jù)預(yù)備

好建立一個(gè)好的模型之前需要解決。那個(gè)練習(xí)通常被稱為''數(shù)據(jù)修

改”。那個(gè)地點(diǎn)是問(wèn)題,我們差不多意識(shí)到的:

1.在一些變量中有缺失值。我們應(yīng)該基于丟失的值的數(shù)量明智地估量這些值并評(píng)估該

變量的重要性。

2.當(dāng)我們查看數(shù)據(jù)的分布時(shí),我們看到,applicantincome和LoanAmount看起來(lái)

在兩端都含有極端值。盡管他們可能有直觀的感受,但應(yīng)適當(dāng)處理。

除了數(shù)值領(lǐng)域的這些問(wèn)題,我們也應(yīng)該看看非數(shù)值領(lǐng)域Gender,

Property_Area,Married,Education和Dependents這些變量,看

看它們是否包含任何有用的信息。

假如你是Pandas的新手,我建議在連續(xù)前進(jìn)之前閱讀這篇文章。它

詳細(xì)介紹了一些有用的數(shù)據(jù)處理技術(shù)。

檢查數(shù)據(jù)集中的缺失值

讓我們看看所有的變量中的缺失值,因?yàn)榇蠖鄶?shù)模型不能處理有缺失

值的數(shù)據(jù),即使他們能夠,輸入它們往往不能關(guān)心更多。因此,讓我們

看看數(shù)據(jù)集中空值/NAN值的數(shù)量:

df.apply(lambdax:sum(x.isnull())^3x15=0)

那個(gè)命令告訴我們每一列中缺失值的數(shù)量,因?yàn)榧偃缰禐槿笔е?/p>

返回

isnull()lo

In[14]:df.apply(lambdax:sum(x.isnull())^axis=0)

Out[14]:Loan_ID0

Gender13

Married3

Dependents15

Education0

Self__Employed32

ApplicantIncome0

Coapplicantincome0

LoanAmount22

Loan__Amount_Term14

Credit_History50

Property_Area0

Loan_Status0

dtype:int64

盡管缺失值數(shù)量不是專門多,但許多變量都有缺失值,它們中的每一

個(gè)都應(yīng)該被估量和補(bǔ)充。通過(guò)這篇文章對(duì)不同的插值技術(shù)進(jìn)行詳細(xì)了

解。

注記住,缺失值可能并不總是NaN。例如,假如loan_amount_term

是0,它是有意義的或者你認(rèn)為是缺失的?我想你的答案是缺失的,你

是對(duì)的。因此我們應(yīng)該檢查那些不切實(shí)際的值。

如何填補(bǔ)LoanAmount的缺失值?

有許多方法來(lái)填補(bǔ)價(jià)值貸款金額的缺失值,最簡(jiǎn)單的確實(shí)是使用均值

來(lái)替換,能夠通過(guò)以下代碼實(shí)現(xiàn):

另一個(gè)極端是能夠建立一個(gè)監(jiān)督學(xué)習(xí)模型來(lái)基于其他變量推測(cè)貸款金

額,然后使用年齡以及其他變量來(lái)推測(cè)。

既然,現(xiàn)在的目標(biāo)是講述數(shù)據(jù)修改的步驟,我寧愿采取一種方法,它

介于這2個(gè)極端方法之間。一個(gè)關(guān)鍵的假設(shè)是,一個(gè)人是否受教育的或

是否自雇人士能夠結(jié)合起來(lái),提供一個(gè)專門好的貸款金額的估量。

第一,讓我們看看箱線圖看是否有某種趨勢(shì)存在:

[Education,SelfEmployed]

因此我們看到在每一組中貸款金額的中位數(shù)的一些變化而這能夠用

來(lái)估量值。但第一,我們必須確保每個(gè)self_employed和Education

變量不應(yīng)該有缺失值。

如我們先前所說(shuō),self_employed有缺失值。讓我們看看頻率表:

In[40]:df[,Self_Employed'].value_counts

Out[40]:No500

Yes82

Name:Self_Employed?dtype:int64

因?yàn)閪86%的值是、'N。",將缺失值估量為''No”是比較可靠的,

有專門高的成功概率。這能夠用下面的代碼來(lái)完成:

df['Self_Employed1].fillna('No'jinplace=True)

現(xiàn)在,我們將創(chuàng)建一個(gè)數(shù)據(jù)透視表,它提供了我們所有Education和

self_employed變量的唯獨(dú)值分組的中位數(shù)。接下來(lái),我們定義了一個(gè)

函數(shù),它返回這些單元格的值,并應(yīng)用它來(lái)填充丟失的貸款金額的值:

table=df.pivot_table(values='LoanAmount',index='Self_Employed1,columns=*E

ducation*,aggfunc=np.median)

#Definefunctiontoreturnvalue

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論