11

私はpandasデータフレームの初心者であり、各列に関数を適用して、列の各要素x、x/maxを計算するようにしたいと思いました。

この質問を参照しましたが、各列の最大値にアクセスできません。よろしく お願いしますPandasDataFrame:すべての列に関数を適用します

入力:

      A  B  C  D
   0  8  3  5  8
   1  9  4  0  4
   2  5  4  3  8
   3  4  8  5  1

出力:

      A     B     C    D
   0  8/9  3/8  5/5  8/8
   1  9/9  4/8  0/5  4/8
   2  5/9  4/8  3/5  8/8
   3  4/9  8/8  5/5  1/8
4

1 に答える 1

13

このようなものが機能するはずです:

>>> from pandas import DataFrame
>>> 
>>> df = DataFrame({"A": [8,9,5,4], "B": [3,4,4,8], "C": [5,0,3,5], "D": [8,4,8,1]})
>>> df.max()
A    9
B    8
C    5
D    8
>>> (df * 1.0)/df.max()
          A      B    C      D
0  0.888889  0.375  1.0  1.000
1  1.000000  0.500  0.0  0.500
2  0.555556  0.500  0.6  1.000
3  0.444444  1.000  1.0  0.125

整数の除算と結果のDataFrameが0と1でいっぱいになるのを避けるために、 sで構成されなくなった(これも機能したはずです)ように乗算dfしたことに注意してください。1.0int.astype(float)

于 2012-12-18T18:03:13.457 に答える