Pandas系列
系列(Series
)是能夠保存任何類型的數據(整數,字符串,浮點數,Python對象等)的一維標記數組。軸標籤統稱爲索引。
pandas.Series
Pandas系列可以使用以下構造函數創建 -
pandas.Series( data, index, dtype, copy)。
構造函數的參數如下 -
編號
參數
描述
1
data
數據採取各種形式,如:ndarray
,list
,constants
2
index
索引值必須是唯一的和散列的,與數據的長度相同。 默認np.arange(n)
如果沒有索引被傳遞。
3
dtype
dtype
用於數據類型。如果沒有,將推斷數據類型
4
copy
複製數據,默認爲false
。
可以使用各種輸入創建一個系列,如 -
- 數組
- 字典
- 標量值或常數
創建一個空的系列
創建一個基本系列是一個空系列。
示例
#import the pandas library and aliasing as pd
import pandas as pd
s = pd.Series()
print s
執行上面示例代碼,輸出結果如下 -
Series([], dtype: float64)
從ndarray創建一個系列
如果數據是ndarray
,則傳遞的索引必須具有相同的長度。 如果沒有傳遞索引值,那麼默認的索引將是範圍(n
),其中n
是數組長度,即[0,1,2,3…. range(len(array))-1] - 1]
。
示例1
#import the pandas library and aliasing as pd
import pandas as pd
import numpy as np
data = np.array(['a','b','c','d'])
s = pd.Series(data)
print s
執行上面示例代碼,輸出結果如下 -
0 a
1 b
2 c
3 d
dtype: object
這裏沒有傳遞任何索引,因此默認情況下,它分配了從0
到len(data)-1
的索引,即:0
到3
。
示例2
#import the pandas library and aliasing as pd
import pandas as pd
import numpy as np
data = np.array(['a','b','c','d'])
s = pd.Series(data,index=[100,101,102,103])
print s
執行上面示例代碼,輸出結果如下 -
100 a
101 b
102 c
103 d
dtype: object
在這裏傳遞了索引值。現在可以在輸出中看到自定義的索引值。
從字典創建一個系列
字典(dict
)可以作爲輸入傳遞,如果沒有指定索引,則按排序順序取得字典鍵以構造索引。 如果傳遞了索引,索引中與標籤對應的數據中的值將被拉出。
示例2
#import the pandas library and aliasing as pd
import pandas as pd
import numpy as np
data = {'a' : 0., 'b' : 1., 'c' : 2.}
s = pd.Series(data)
print s
執行上面示例代碼,輸出結果如下 -
a 0.0
b 1.0
c 2.0
dtype: float64
注意 - 字典鍵用於構建索引。
示例
#import the pandas library and aliasing as pd
import pandas as pd
import numpy as np
data = {'a' : 0., 'b' : 1., 'c' : 2.}
s = pd.Series(data,index=['b','c','d','a'])
print s
執行上面示例代碼,輸出結果如下 -
b 1.0
c 2.0
d NaN
a 0.0
dtype: float64
注意觀察 - 索引順序保持不變,缺少的元素使用NaN(不是數字)填充。
從標量創建一個系列
如果數據是標量值,則必須提供索引。將重複該值以匹配索引的長度。
#import the pandas library and aliasing as pd
import pandas as pd
import numpy as np
s = pd.Series(5, index=[0, 1, 2, 3])
print s
執行上面示例代碼,得到以下結果 -
0 5
1 5
2 5
3 5
dtype: int64
從具有位置的系列中訪問數據
系列中的數據可以使用類似於訪問ndarray
中的數據來訪問。
示例-1
檢索第一個元素。比如已經知道數組從零開始計數,第一個元素存儲在零位置等等。
import pandas as pd
s = pd.Series([1,2,3,4,5],index = ['a','b','c','d','e'])
#retrieve the first element
print s[0]
執行上面示例,得到以下結果 -
1
示例-2
檢索系列中的前三個元素。 如果a:
被插入到其前面,則將從該索引向前的所有項目被提取。 如果使用兩個參數(使用它們之間),兩個索引之間的項目(不包括停止索引)。
import pandas as pd
s = pd.Series([1,2,3,4,5],index = ['a','b','c','d','e'])
#retrieve the first three element
print s[:3]
執行上面示例,得到以下結果 -
a 1
b 2
c 3
dtype: int64
示例-3
檢索最後三個元素,參考以下示例代碼 -
import pandas as pd
s = pd.Series([1,2,3,4,5],index = ['a','b','c','d','e'])
#retrieve the last three element
print s[-3:]
執行上面示例代碼,得到以下結果 -
c 3
d 4
e 5
dtype: int64
使用標籤檢索數據(索引)
一個系列就像一個固定大小的字典,可以通過索引標籤獲取和設置值。
示例1
使用索引標籤值檢索單個元素。
import pandas as pd
s = pd.Series([1,2,3,4,5],index = ['a','b','c','d','e'])
#retrieve a single element
print s['a']
執行上面示例代碼,得到以下結果 -
1
示例2
使用索引標籤值列表檢索多個元素。
import pandas as pd
s = pd.Series([1,2,3,4,5],index = ['a','b','c','d','e'])
#retrieve multiple elements
print s[['a','c','d']]
執行上面示例代碼,得到以下結果 -
a 1
c 3
d 4
dtype: int64
示例3
如果不包含標籤,則會出現異常。
import pandas as pd
s = pd.Series([1,2,3,4,5],index = ['a','b','c','d','e'])
#retrieve multiple elements
print s['f']
執行上面示例代碼,得到以下結果 -
…
KeyError: 'f'