我初学Python,今天开始实践,用Python读取一个表格文件,N行M列,数字间用制表符隔开,读完之后选取一行看效果,发现读取的数据是以str类型储存的:#!/usr/bin/python
# Filename: cotalogue.py
catalogue = []
f = open('NGC1868.Final.cat')
c = f.readlines()
Num = 0
for item in c:
item = item.rstrip()
v = item.split(' ')
catalogue.append(v)
print catalogue[0]
['0', '308.080000000000', '73.8000000000000', '-63.9551230737155', '78.6517235172791', '1.23000000000000', '612.600000000000', '-0.0290000000000000', '0.0720000000000000', '85', '1', '55320.8300000000', '41.4170000000000', '19.0960000000000', '19.0710000000000', '0.00400000000000000', '1.86000000000000', '290', '-0.0460000000000000', '0.0930000000000000', '0.00700000000000000', '55673.1500000000', '36.0740000000000', '18.2040000000000', '18.1680000000000', '0.00200000000000000', '0.980000000000000', '539.500000000000', '-0.0230000000000000', '0.0490000000000000', '0.00800000000000000']
这让我很难继续接下来的计算,比如要算此行的第15个元素与第25个元素的差,将会告诉我'-'号运算符不能用于str之间:
print catalogue[0][14]-catalogue[0][24]
TypeError: unsupported operand type(s) for -: 'str' and 'str'
这个问题有没有人遇到过?能否告诉怎么改进这个代码好让Python不将数字识别为str?谢谢好心人的帮助。
1、打开软件,新建python项目,如图所示。
2、 右键菜单中创建.py文件,如图所示。
3、步骤中文件输入代码如下。
4、空白后,右键菜单中选择【Run 'test'】。
5、查看运行结果如下图所示。
6、需要转换string到float,直接调用图中的函数即可。
TypeError: float() argument must be a string or a number
追答不好意思,没仔细看你的代码。
107011162 说的对。v是个数组,所以你需要再加一个循环,【当然用map更好,但不知道你能否理解】
catalogue.append(v)改成
catalogue.append([ float(vi) for vi in v ])
以上2种答案结果并不一样。上面是一维数组,下面是二维数组。
不行,TypeError: float() argument must be a string or a number
追答不好意思,没看清楚误导了你。呵呵~~
楼下assistant2012_ 和107011162说得好。用map就行了。
将其改成catalogue.append(map(float,v))就行了。