栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

numpy.genfromtxt生成看起来像元组的数组,而不是2D数组-为什么?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

numpy.genfromtxt生成看起来像元组的数组,而不是2D数组-为什么?

返回的结果称为 结构化ndarray
,例如,请参见此处:http :
**//docs.scipy.org/doc/numpy/user/basics.rec.html**
。这是因为您的数据不是同质的,即并非所有元素都具有相同的类型:数据既包含字符串(前两列)又包含浮点数。Numpy数组必须是同质的(请参阅此处以获得解释)。


结构化数组通过为每个记录或行使用元组来“解决”这种同质性约束,这就是返回数组为1D的原因:一系列元组,但是每个元组(行)都包含多个字段,因此您可以将其视为行和列。可访问不同的列,

a['nameofcolumn']
例如
a['Julian_Day']

在删除前两列的转换器时,它返回2D数组的原因是,在这种情况下,它会

genfromtxt
考虑相同类型的所有数据,并且会返回一个普通的ndarray(默认类型为float,但是您可以使用该
dtype
参数)。

编辑 :如果要使用列名,则可以使用

names
参数(并且
skip_header
仅将参数设置为3):

a2 = np.genfromtxt("input.txt", delimiter=',', skip_header=3, names = True, dtype = None,       usecols=[0, 1] + radii_indices, converters={0: date_conv, 1: time_conv})

你可以做例如:

>>> a2['Dateddmmyyyy']array(['06/03/2006', '06/03/2006', '18/03/2006', '19/03/2006',       '19/03/2006', '19/03/2006', '19/03/2006', '19/03/2006',       '19/03/2006', '19/03/2006'],       dtype='|S10')


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/638220.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号