数値の位置を変更せずに、numpy配列をランク付けしたいと思います。以下のnumpy関数を使用してそれを行うことができましたが、「NaN」値もランク付けされ続けます。それらを無視して、代わりに実数値をランク付けするにはどうすればよいですか。どんな助けでも大歓迎です!ありがとう!
これが私のコードです:
import numpy as np
hr=[]
for line in open('file.txt' ,'r'):
hr.append(line.strip().split('\t'))
tf=[]
for i in range(1,len(hr)):
print hr[i][1:13]
tf.append(hr[i][1:13])
for rows in range(0,len(tf)):
array = np.array([tf[rows]],dtype(float))
print array
order = array.argsort()
ranks = order.argsort()
print ranks
ここで、各配列行はtfから次のようになります。
array=['NaN', '20', '383.333', 'NaN', 'NaN', 'NaN', '5', '100', '129', '122.5', 'NaN', 'NaN']
必要な出力:
ranks=array['NaN', 1, 5, 'NaN', 'NaN', 'NaN', 0, 2, 4, 3, 'NaN', 'NaN']
上記のコードでの実際の出力:
ranks=array([ 6, 3, 4, 7, 8, 9, 5, 0, 2, 1, 10, 11])
私はPythonを初めて使用するので、助けていただければ幸いです。