繁体   English   中英

拆分列表中的元素

[英]split elements in a list

我正在尝试拆分某些列表中的元素,但我只能获取每个字符

示例:拆分这些列表

[999.7382621, -1.4637250000000002]
[-1.5490111999999998, 1.5490111999999998]

用这个代码

elements = [map(str, line.split(",")) for line in mylists]

我得到这个结果:

[['9'], ['9'], ['9'], ['.'], ['7'], ['3'], ['8'], ['2'], ['6'], ['2'], ['1'],['', ''], ['-'], ['1'], ['.'], ['4'], ['6'], ['3'], ['7'], ['2'], ['5']]
[['-'], ['1'], ['.'], ['5'], ['4'], ['9'], ['0'], ['1'], ['1'], ['2'], ['', ''], ['1'], ['.'], ['5'], ['4'], ['9'], ['0'], ['1'], ['1'], ['2']]

我想得到

[['999.7382621'],['-1.4637250000000002']]
[['-1.5490111999999998'],['1.5490111999999998']]

我在这里错过了什么? 谢谢

你为什么不使用类似的东西

>>> a = [999.7382621, -1.4637250000000002]
>>> map(lambda x: [str(x)], a)
[['999.7382621'], ['-1.463725']]
>>> 

为什么要使用拆分?

如果您的原始数据是文本文件的行:

In [135]: line = '[999.7382621, -1.4637250000000002]'

In [136]: import ast

In [137]: ast.literal_eval(line)
Out[137]: [999.7382621, -1.4637250000000002]

In [138]: [[x] for x in ast.literal_eval(line)]
Out[138]: [[999.7382621], [-1.4637250000000002]]

看起来mylists变量是一个字符串,当你说

elements = [map(str, line.split(",")) for line in mylists]

你实际上不是在行上而是在字符上迭代。 尝试:

elements = [map(str, line.split(",")) for line in mylists.strip('\n').split('\n')]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM