亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python中pandas.DataFrame的簡單操作方法(創(chuàng)建、索引、增添與刪除)

 更新時間:2017年03月12日 14:57:57   作者:赤兔DD  
這篇文章主要介紹了python中pandas.DataFrame的簡單操作方法,其中包括創(chuàng)建、索引、增添與刪除等的相關資料,文中介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。

前言

最近在網上搜了許多關于pandas.DataFrame的操作說明,都是一些基礎的操作,但是這些操作組合起來還是比較費時間去正確操作DataFrame,花了我挺長時間去調整BUG的。我在這里做一些總結,方便你我他。感興趣的朋友們一起來看看吧。

一、創(chuàng)建DataFrame的簡單操作:

1、根據字典創(chuàng)造:

In [1]: import pandas as pd
In [3]: aa={'one':[1,2,3],'two':[2,3,4],'three':[3,4,5]}
In [4]: bb=pd.DataFrame(aa)
In [5]: bb
Out[5]: 
 one three two
0 1 3 2
1 2 4 3
2 3 5 4`

字典中的keys就是DataFrame里面的columns,但是沒有index的值,所以需要自己設定,不設定默認是從零開始計數。

bb=pd.DataFrame(aa,index=['first','second','third'])
bb
Out[7]: 
 one three two
first 1 3 2
second 2 4 3
third 3 5 4

2、從多維數組中創(chuàng)建

import numpy as np
In [9]: del aa
In [10]: aa=np.array([[1,2,3],[4,5,6],[7,8,9]])
In [11]: aa
Out[11]: 
array([[1, 2, 3],
 [4, 5, 6],
 [7, 8, 9]])
In [12]: bb=pd.DataFrame(aa)
In [13]: bb
Out[13]: 
 0 1 2
0 1 2 3
1 4 5 6
2 7 8 9

從多維數組中創(chuàng)建就需要為DataFrame賦值columns和index,否則就是默認的,很丑的。

bb=pd.DataFrame(aa,index=[22,33,44],columns=['one','two','three'])
In [15]: bb
Out[15]: 
 one two three
22 1 2 3
33 4 5 6
44 7 8 9

3、用其他的DataFrame創(chuàng)建

bb=pd.DataFrame(aa,index=[22,33,44],columns=['one','two','three'])
bb
Out[15]: 
 one two three
22 1 2 3
33 4 5 6
44 7 8 9
cc=bb[['one','three']].copy()
Cc
Out[17]: 
 one three
22 1 3
33 4 6
44 7 9

這里的拷貝是深拷貝,改變cc中的值并不能改變bb中的值。

cc['three'][22]=5
bb
Out[19]: 
 one two three
22 1 2 3
33 4 5 6
44 7 8 9

cc
Out[20]: 
 one three
22 1 5
33 4 6
44 7 9

二、DataFrame的索引操作:

對于一個DataFrame來說,索引是最煩的,最易出錯的。

1、索引一列或幾列,比較簡單:

bb['one']
Out[21]: 
22 1
33 4
44 7
Name: one, dtype: int32

多個列名需要將輸入的列名存在一個列表里,才是個collerable的變量,否則會報錯。

bb[['one','three']]
Out[29]: 
 one three
22 1 3
33 4 6
44 7 9

2、索引一條記錄或幾條記錄:

bb[1:3]
Out[27]: 
 one two three
33 4 5 6
44 7 8 9
bb[:1]
Out[28]: 
 one two three
22 1 2 3

這里注意冒號是必須有的,否則是索引列的了。

3、索引某幾列的變量的某幾條記錄,這個折磨了我好久:

第一種

bb.loc[[22,33]][['one','three']]
Out[30]: 
 one three
22 1 3
33 4 6

這種不能改變這里面的值,你只是能讀值,不能寫值,可能和loc()函數有關:

bb.loc[[22,33]][['one','three']]=[[2,2],[3,6]]
In [32]: bb
Out[32]: 
 one two three
22 1 2 3
33 4 5 6
44 7 8 9

第二種:也是只能看

bb[['one','three']][:2]
Out[33]: 
 one three
22 1 3
33 4 6

想要改變其中的值就會報錯。

In [34]: bb[['one','three']][:2]=[[2,2],[2,2]]
-c:1: SettingWithCopyWarning: A value is trying to be set on a copy of a slice from a DataFrame.
Try using .loc[row_index,col_indexer] = value instead
F:\Anaconda\lib\site-packages\pandas\core\frame.py:1999: SettingWithCopyWarning: A value is trying to be set on a copy of a slice from a DataFrame
 return self._setitem_slice(indexer, value)

第三種:可以改變數據的值?。?!

Iloc是按照數據的行列數來索引,不算index和columns

bb.iloc[2:3,2:3]
Out[36]: 
 three
44 9

bb.iloc[1:3,1:3]
Out[37]: 
 two three
33 5 6
44 8 9
bb.iloc[0,0]
Out[38]: 1

下面是證明:

bb.iloc[0:4,0:2]=[[9,9],[9,9],[9,9]]
In [45]: bb
Out[45]: 
 one two three
22 9 9 3
33 9 9 6
44 9 9 9

三、在原有的DataFrame上新建一個columns或幾個columns

1、什么都不用的,只能單獨創(chuàng)建一列,多列并不好使,親測無效:

bb['new']=[2,3,4]
bb
Out[51]: 
 one two three new
22 9 9 3 2
33 9 9 6 3
44 9 9 9 4
bb[['new','new2']]=[[2,3,4],[5,3,7]]
KeyError: "['new' 'new2'] not in index"

賦予的list基本就是按照所給index值順序賦值,可是一般我們是要對應的index進行賦值,想要更高級的賦值就看后面的了。

2、使用字典進行多列按index賦值:

aa={33:[234,44,55],44:[657,77,77],22:[33,55,457]}
In [58]: bb=bb.join(pd.DataFrame(aa.values(),columns=['hi','hello','ok'],index=aa.keys()))
In [59]: bb
Out[59]: 
 one two three new hi hello ok
22 9 9 3 2 33 55 457
33 9 9 6 3 234 44 55
44 9 9 9 4 657 77 77

這里aa是一個字典和列表的嵌套,相當于一條記錄,使用keys當做index名而不是一般默認的columns名。達到了按index多列匹配的目的。由于dict()儲存是混亂的,之間用dict()而不給他的index賦值會記錄錯亂,這一點注意值得注意。

四、刪除多列或多記錄:

刪除列

bb.drop(['new','hi'],axis=1)
Out[60]: 
 one two three hello ok
22 9 9 3 55 457
33 9 9 6 44 55
44 9 9 9 77 77

刪除記錄

bb.drop([22,33],axis=0)
Out[61]: 
 one two three new hi hello ok
44 9 9 9 4 657 77 77

跟大家分享一篇關于python中pandas.DataFrame對行與列求和及添加新行與列示例,感興趣的朋友們可以看看。

DataFrame還有很多功能還沒有涉及,等以后有涉及到,看完官網的API之后,還會繼續(xù)分享,everything is ok。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • Python中循環(huán)后使用list.append()數據被覆蓋問題的解決

    Python中循環(huán)后使用list.append()數據被覆蓋問題的解決

    這篇文章主要給大家介紹了關于Python中循環(huán)后使用list.append()數據被覆蓋問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-07-07
  • python繪制柱形圖的方法

    python繪制柱形圖的方法

    這篇文章主要為大家詳細介紹了python繪制柱形圖的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • python實現上傳樣本到virustotal并查詢掃描信息的方法

    python實現上傳樣本到virustotal并查詢掃描信息的方法

    這篇文章主要介紹了python實現上傳樣本到virustotal并查詢掃描信息的方法,是比較實用的技巧,需要的朋友可以參考下
    2014-10-10
  • 容易被忽略的Python內置類型

    容易被忽略的Python內置類型

    這篇文章主要介紹了容易被忽略的Python內置類型,幫助大家更好的理解和學習python,感興趣的朋友可以了解下
    2020-09-09
  • python實現簡單的TCP代理服務器

    python實現簡單的TCP代理服務器

    這篇文章主要介紹了python實現簡單的TCP代理服務器,包含了完整的實現過程及對應的源碼與說明文檔下載,非常具有參考借鑒價值,需要的朋友可以參考下
    2014-10-10
  • 詳解Python中的文件操作

    詳解Python中的文件操作

    今天這篇文章給大家介紹Python中的文件操作,文章內容介紹的很詳細,有需要的可以參考借鑒。
    2016-08-08
  • pandas 如何分割字符的實現方法

    pandas 如何分割字符的實現方法

    這篇文章主要介紹了pandas 如何分割字符的實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • python抽樣方法解讀及實現過程

    python抽樣方法解讀及實現過程

    這篇文章主要介紹了python抽樣方法解讀及實現過程講解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • python3+PyQt5圖形項的自定義和交互 python3實現page Designer應用程序

    python3+PyQt5圖形項的自定義和交互 python3實現page Designer應用程序

    這篇文章主要為大家詳細介紹了python3+PyQt5圖形項的自定義和交互,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • python 測試實現方法

    python 測試實現方法

    使用python進行測試也足夠簡明了
    2008-12-12

最新評論