我正在编写一个程序,根据特定公司的能量值对氨基酸的名称进行排序。
我已将相关数据提取到以下numpy数组。
我试过这个
In[37]: Data = np.array([
['ASN 205', -9.64164],
['LEU 206', -8.985774],
['ASN 207', -7.314434],
['PRO 208', -4.105338],
['ASN 209', -2.092342],
['GLY 210', -2.101412],
['LYS 211', -2.483852],
['ARG 212', -24.20364],
['SER 213', -1.181002],
['VAL 214', 0.057618]])
In[38]: ind3 = np.lexsort((Data[:,0],Data[:,1]))
In[39]: Result = Data[ind3]
In[40]: Result
Out[40]:
array([['SER 213', '-1.181002'],
['ASN 209', '-2.092342'],
['GLY 210', '-2.101412'],
['LYS 211', '-2.483852'],
['ARG 212', '-24.20364'],
['PRO 208', '-4.105338'],
['ASN 207', '-7.314434'],
['LEU 206', '-8.985774'],
['ASN 205', '-9.64164'],
['VAL 214', '0.057618']],
dtype='|S9')
但这里的问题是浮点值是以字典方式排列的。我想先按照它们的价值订购-24.20364然后......- 2.483852。
我该怎么做?
答案 0 :(得分:2)
解释:np.array
将所有传递的参数转换为适合所有参数的最大类型,即你的float在第1行转换。
您可以使用具有特定数据类型的元组,如下所示:
Data = np.array([
('ASN 205', -9.64164),
('LEU 206', -8.985774),
('ASN 207', -7.314434),
('PRO 208', -4.105338),
('ASN 209', -2.092342),
('GLY 210', -2.101412),
('LYS 211', -2.483852),
('ARG 212', -24.20364),
('SER 213', -1.181002),
('VAL 214', 0.057618)], dtype=[('f', '|S9'), ('g', float)])
ind3 = np.lexsort((Data['f'], Data['g']))
Result = Data[ind3]Out[8]:
输出:
array([('ARG 212', -24.20364), ('ASN 205', -9.64164),
('LEU 206', -8.985774), ('ASN 207', -7.314434),
('PRO 208', -4.105338), ('LYS 211', -2.483852),
('GLY 210', -2.101412), ('ASN 209', -2.092342),
('SER 213', -1.181002), ('VAL 214', 0.057618)],
dtype=[('f', 'S9'), ('g', '<f8')])