Pythonパンダ-関数適用
独自または別のライブラリの関数をPandasオブジェクトに適用するには、3つの重要な方法に注意する必要があります。これらの方法については、以下で説明します。使用する適切な方法は、関数がDataFrame全体、行単位、列単位、または要素単位のいずれで動作することを期待しているかによって異なります。
- テーブルワイズ関数適用:pipe()
- 行または列のワイズ関数適用:apply()
- 要素ごとの関数適用:applymap()
テーブルワイズ関数適用
関数と適切な数のパラメーターをパイプ引数として渡すことにより、カスタム操作を実行できます。したがって、操作はDataFrame全体に対して実行されます。
たとえば、DataFrameのすべての要素に値2を追加します。次に、
加算関数
加算関数は、パラメーターとして2つの数値を加算し、合計を返します。
def adder(ele1,ele2):
return ele1+ele2
次に、カスタム関数を使用してDataFrameで操作を実行します。
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.pipe(adder,2)
プログラム全体を見てみましょう-
import pandas as pd
import numpy as np
def adder(ele1,ele2):
return ele1+ele2
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.pipe(adder,2)
print df.apply(np.mean)
その output 次のとおりです-
col1 col2 col3
0 2.176704 2.219691 1.509360
1 2.222378 2.422167 3.953921
2 2.241096 1.135424 2.696432
3 2.355763 0.376672 1.182570
4 2.308743 2.714767 2.130288
行または列のワイズ関数適用
任意の関数は、DataFrameまたはPanelの軸に沿って適用できます。 apply()メソッド。記述統計メソッドと同様に、オプションの軸引数を取ります。デフォルトでは、操作は列ごとに実行され、各列は配列のようになります。
例1
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.apply(np.mean)
print df.apply(np.mean)
その output 次のとおりです-
col1 -0.288022
col2 1.044839
col3 -0.187009
dtype: float64
通過することによって axis パラメータ、操作は行ごとに実行できます。
例2
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.apply(np.mean,axis=1)
print df.apply(np.mean)
その output 次のとおりです-
col1 0.034093
col2 -0.152672
col3 -0.229728
dtype: float64
例3
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.apply(lambda x: x.max() - x.min())
print df.apply(np.mean)
その output 次のとおりです-
col1 -0.167413
col2 -0.370495
col3 -0.707631
dtype: float64
ElementWise関数適用
すべての関数をベクトル化できるわけではありません(別の配列を返すNumPy配列も値もありません)。 applymap() DataFrameと analogously map() on Seriesは、単一の値を取り、単一の値を返すPython関数を受け入れます。
例1
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
# My custom function
df['col1'].map(lambda x:x*100)
print df.apply(np.mean)
その output 次のとおりです-
col1 0.480742
col2 0.454185
col3 0.266563
dtype: float64
例2
import pandas as pd
import numpy as np
# My custom function
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.applymap(lambda x:x*100)
print df.apply(np.mean)
その output 次のとおりです-
col1 0.395263
col2 0.204418
col3 -0.795188
dtype: float64