<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
Pandas是Python下一個開源資料分析的庫,它提供的資料結構DataFrame極大的簡化了資料分析過程中一些繁瑣操作。
建立DataFrame. DataFrame是一張二維的表,大家可以把它想象成一張Excel表單或者Sql表。
Excel 2007及其以後的版本的最大行數是1048576,最大列數是16384,超過這個規模的資料Excel就會彈出個框框“此文字包含多行文字,無法放置在一個工作表中”。
Pandas處理上千萬的資料是易如反掌的sh事情,同時隨後我們也將看到它比SQL有更強的表達能力,可以做很多複雜的操作,要寫的code也更少。 說了一大堆它的好處,要實際感觸還得動手碼程式碼。
首要的任務就是建立一個DataFrame,它有幾種建立方式:
其中,我最喜歡的是通過二維ndarray建立DataFrame,因為程式碼敲得最少:
import pandas as pd import numpy as np df = pd.DataFrame(np.random.randn( 3 , 4 )) df 0 1 2 3 0 0.236175 - 0.394792 - 0.171866 0.304012 1 0.651926 0.989046 0.160389 0.482936 2 - 1.039824 0.401105 - 0.492714 - 1.220438
當然你還可以從mysql資料庫或者csv檔案中載入資料到dataframe。
dataframe中index用來標識行,column標識列,shape表示維度。
# 獲得行索引資訊 df.index # 獲得列索引資訊 df.columns # 獲得df的size df.shape # 獲得df的行數 df.shape[0] # 獲得df的 列數 df.shape[1] # 獲得df中的值 df.values
通過describe方法,我們可以對df中的資料有個大概的瞭解:
df.describe() 0 1 2 3 count 3.000000 3.000000 3.000000 3.000000 mean - 0.050574 0.331786 - 0.168064 - 0.144496 std 0.881574 0.694518 0.326568 0.936077 min - 1.039824 - 0.394792 - 0.492714 - 1.220438 25 % - 0.401824 0.003156 - 0.332290 - 0.458213 50 % 0.236175 0.401105 - 0.171866 0.304012 75 % 0.444051 0.695076 - 0.005739 0.393474 max 0.651926 0.989046 0.160389 0.482936
按照列名select:
df[ 0 ] 0 0.236175 1 0.651926 2 - 1.039824
按照行數select:
df[: 3 ] #選取前3行
按照索引select:
df.loc[ 0 ] 0 0.236175 1 - 0.394792 2 - 0.171866 3 0.304012
按照行數和列數select:
df.iloc[ 3 ] #選取第3行 df.iloc[ 2 : 4 ] #選取第2到第3行 df.iloc[ 0 , 1 ] #選取第0行1列的元素 dat.iloc[: 2 , : 3 ] #選取第0行到第1行,第0列到第2列區域內的元素 df1.iloc[[1,3,5],[1,3]] #選取第1,3,5行,第1,3列區域內的元素
刪除某列:
del df[0] df 1 2 3 0 - 0.394792 - 0.171866 0.304012 1 0.989046 0.160389 0.482936 2 0.401105 - 0.492714 - 1.220438
刪除某行:
5 df.drop(0) 1 2 3 1 0.989046 0.160389 0.482936 2 0.401105 - 0.492714 - 1.220438
基本運算:
df[ 4 ] = df[ 1 ] + df[ 2 ] 1 2 3 4 0 - 0.394792 - 0.171866 0.304012 - 0.566659 1 0.989046 0.160389 0.482936 1.149435 2 0.401105 - 0.492714 - 1.220438 - 0.091609
map運算,和python中的map有些類似:
df[ 4 ]. map ( int ) 0 0 1 1 2 0
apply運算:
df. apply ( sum ) 1 0.995359 2 - 0.504192 3 - 0.433489 4 0.491167
pandas中的group by 操作是我的最愛,不用把資料匯入excel或者mysql就可以進行靈活的group by 操作,簡化了分析過程。
df[ 0 ] = [ 'A' , 'A' , 'B' ] df 1 2 3 4 0 0 - 0.394792 - 0.171866 0.304012 - 0.566659 A 1 0.989046 0.160389 0.482936 1.149435 A 2 0.401105 - 0.492714 - 1.220438 - 0.091609 B g = df.groupby([ 0 ]) g.size() A 2 B 1 g. sum () 1 2 3 4 0 A 0.594254 - 0.011478 0.786948 0.582776 B 0.401105 - 0.492714 - 1.220438 - 0.091609
dataframe可以使用to_csv方法方便地匯出到csv檔案中,如果資料中含有中文,一般encoding指定為”utf-8″,否則匯出時程式會因為不能識別相應的字串而丟擲異常,index指定為False表示不用匯出dataframe的index資料。
df.to_csv(file_path, encoding='utf-8', index=False) df.to_csv(file_path, index=False)
到此這篇關於Pandas中DataFrame操作的文章就介紹到這了,更多相關Pandas DataFrame操作內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45