首页 > 解决方案 > 乘以 Python MaskedColumn

问题描述

我正在读取 .html 数据文件,我想做的就是将 data['ra'] 列乘以 15。但是,我收到一个错误::

>>> data = ascii.read("Ldwarf.html", format="html", encoding = "ISO-8859-1")  
>>> data

<Table masked=True length=919>
designation ra  decl    
2MASS J00011217+1535355 0.0200472   +15.593194  
2MASS J00025097+2454141 0.0474917   +24.903917  
2MASS J00040288-6410358 0.0674667   -64.176611  

>>> data['ra'] 
<MaskedColumn name='ra' dtype='str10' length=919>
decimal hr
0.0200472
0.0474917
...
23.9783250
23.9993389

>>> data['ra'] = data['ra'].filled([-9.99])
>>> data['ra'] = data['ra']*15.

TypeError: ufunc 'multiply' did not contain a loop with signature matching 
types dtype('<U32') dtype('<U32') dtype('<U32')

到底是怎么回事??

标签: pythonastropy

解决方案


正如您在 html 文件中看到的那样,应该有 918 行,但您得到了 919。具有单位定义的行被读取为第一个数据行,它把所有东西都弄乱了。这就是为什么您将第一个“ra”视为“十进制 hr”而不是数字,并且列数据类型被推断为 dtype='str10'。

您可以使用“data_start”参数丢弃有问题的行:

data = ascii.read("Ldwarf.html", 
                  format="html", 
                  encoding="ISO-8859-1", 
                  data_start=2)

现在可以正确推断输入类型,将“ra”乘以 15 应该没有任何问题。


推荐阅读