Pythonパンダ-シリーズ
Seriesは、任意のタイプ(整数、文字列、浮動小数点数、Pythonオブジェクトなど)のデータを保持できる1次元のラベル付き配列です。軸ラベルはまとめてインデックスと呼ばれます。
pandas.Series
パンダシリーズは、次のコンストラクターを使用して作成できます-
pandas.Series( data, index, dtype, copy)
コンストラクターのパラメーターは次のとおりです-
シニア番号 | パラメータと説明 |
---|---|
1 | data データは、ndarray、list、constantsなどのさまざまな形式を取ります |
2 | index インデックス値は、データと同じ長さで、一意でハッシュ可能である必要があります。デフォルトnp.arrange(n) インデックスが渡されない場合。 |
3 | dtype dtypeはデータ型用です。Noneの場合、データ型が推測されます |
4 | copy データをコピーします。デフォルトFalse |
シリーズは、次のようなさまざまな入力を使用して作成できます。
- Array
- Dict
- スカラー値または定数
空のシリーズを作成する
作成できる基本シリーズは空シリーズです。
例
#import the pandas library and aliasing as pd
import pandas as pd
s = pd.Series()
print s
その output 次のとおりです-
Series([], dtype: float64)
ndarrayからシリーズを作成する
データがndarrayの場合、渡されるインデックスは同じ長さである必要があります。インデックスが渡されない場合、デフォルトでインデックスはrange(n) どこ n は配列の長さ、つまり[0,1,2,3…。 range(len(array))-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
その output 次のとおりです-
0 a
1 b
2 c
3 d
dtype: object
インデックスを渡さなかったため、デフォルトでは、0から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
その output 次のとおりです-
100 a
101 b
102 c
103 d
dtype: object
ここにインデックス値を渡しました。これで、カスタマイズされたインデックス値が出力に表示されます。
dictからシリーズを作成する
A dict入力として渡すことができ、インデックスが指定されていない場合、辞書キーはソートされた順序で取得されてインデックスが作成されます。場合index が渡されると、インデックスのラベルに対応するデータの値が引き出されます。
例1
#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
その output 次のとおりです-
a 0.0
b 1.0
c 2.0
dtype: float64
Observe −辞書キーはインデックスの作成に使用されます。
例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,index=['b','c','d','a'])
print s
その output 次のとおりです-
b 1.0
c 2.0
d NaN
a 0.0
dtype: float64
Observe −インデックスの順序は保持され、欠落している要素はNaN(数値ではない)で埋められます。
Scalarからシリーズを作成する
データがスカラー値の場合、インデックスを指定する必要があります。値は、の長さに一致するように繰り返されますindex
#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
その output 次のとおりです-
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]
その output 次のとおりです-
1
例2
シリーズの最初の3つの要素を取得します。その前に:を挿入すると、そのインデックス以降のすべてのアイテムが抽出されます。2つのパラメーター(間に:を含む)が使用されている場合、2つのインデックス間のアイテム(停止インデックスを含まない)
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]
その output 次のとおりです-
a 1
b 2
c 3
dtype: int64
例3
最後の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:]
その output 次のとおりです-
c 3
d 4
e 5
dtype: int64
ラベル(インデックス)を使用してデータを取得する
シリーズは固定サイズのようなものです dict インデックスラベルで値を取得および設定できるという点で。
例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']
その output 次のとおりです-
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']]
その output 次のとおりです-
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']
その output 次のとおりです-
…
KeyError: 'f'