Python 列表元素字符串转浮点

Python 列表元素字符串转浮点在网络爬虫或者读取文件中的数据时,很多时候读取出来的数值是字符串形式的,这些字符串形式的数据并不能用来作计算或者更深入的操作,因此我们需要把他们转换为数值的形式。简单粗暴的for循环假设,这里有一个以字符串形式存储数值的列表,具体如下:a=[‘2′,’3.5′,’10’,’88’,’32.66′]我们需要将其转换为浮点的形式,最简单粗暴直接的方法,可以使用…

大家好,又见面了,我是你们的朋友全栈君。

在网络爬虫或者读取文件中的数据时,很多时候读取出来的数值是字符串形式的,这些字符串形式的数据并不能用来作计算或者更深入的操作,因此我们需要把他们转换为数值的形式。

简单粗暴的 for 循环

假设,这里有一个以字符串形式存储数值的列表,具体如下:

a = ['2', '3.5', '10', '88', '32.66']

我们需要将其转换为浮点的形式,最简单粗暴直接的方法,可以使用 for 循环 来处理,方法如下:

a_float = []
for num in a:
    a_float.append(float(num))

a_float
>> [2.0, 3.5, 10.0, 88.0, 32.66]

我们通过 for 循环, 把列表中的每一个数值都用 float() 函数将其转换成浮点的形式,然后再将转换后的值添加到一个新列表中,最终我们即可得到一个浮点值得列表。

更优雅的 map() 方法

如果我们每次都需要写一个 for 循环,这样一来显得不优雅,二来代码看起来也很冗长。我们也可以使用 map() 方法来处理。具体代码如下:

a_float_m = map(float, a)
a_float_m
>> <map at 0x109854da0>
a_float_m = list(a_float_m)
[2.0, 3.5, 10.0, 88.0, 32.66]

和刚才的 for 循环 对比,我们使用 map() 方法,只需要一行代码就可以完成。这里有一点需要注意,在 Python2 中,map() 返回的是列表,而在 Python3 中,返回的是迭代器。因此,我们这里如果想得到一个列表,我们还需要使用以下 list()

意外的处理

很多时候,我们的原始数据未必是那么完美,假如我们原始的列表中,有一些不能转换的数据,那情况将如何?接下来,我们对 a 列表进行一些改造。

a.append('a')
a
>> ['2', '3.5', '10', '88', '32.66', 'a']

接下来,我们还是对 a 使用 map() 方法:

a_float_new = list(map(float, a))
>> ValueError: could not convert string to float: 'a'

这时,我们的程序就报错了,因为字符串不能转成浮点数值。如果我们还希望继续完成这个转换,我们就需要对改造一下处理的函数,具体代码如下:

def safe_float(number):
    try:
        return float(number)
    except:
        return None

a_float_new = list(map(safe_float, a))
a_float_new
>> [2.0, 3.5, 10.0, 88.0, 32.66, None]

我们先约定好,将不能转换的值保存为 None,然后编写了一个 safe_float() 的方法进行处理,随后再将这个函数传到 map() 中,这样,最后我们就能得到处理完成后的列表了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137841.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 挖矿病毒攻击的排查处置手册

    挖矿病毒攻击的排查处置手册一、背景在用户不知情或未经允许的情况下,占用系统资源和网络资源进行挖矿,影响用户的网络和资源,从而获取虚拟币牟利。为了帮助应对恶意挖矿程序攻击,发现和清除恶意挖矿程序,防护和避免感染恶意挖矿程序,整理了如下针对挖矿活动相关的现状分析和检测处置建议。二、为什么会感染恶意挖矿程序通常遇到企业内网主机感染恶意挖矿程序,或者网站、服务器以及使用的云服务被植入恶意挖矿程序的时候,都不免提出“为什么会感染恶意挖矿程序,以及是如何感染的”诸如此类的问题,目前感染恶意挖矿程序的主要方式:2.1.利用类似其他病毒木

    2022年5月29日
    58
  • AV1编码技术分析

    AV1编码技术分析av1是一种新兴的开源、版权免费的视频压缩格式,由开放媒体联盟(AOMedia)行业联盟于2018年初联合开发并最终定稿。AV1开发的主要目标是在当前的编解码器基础上获得可观的压缩率提升,同时确保解码的复杂性和硬件的实际可行性。本文简要介绍了AV1中的关键编码技术,并与VP9和HEVC进行了初步的压缩性能比较。索引:视频压缩,AV1,开放媒体联盟,开源视频编码一、引言在过去的十年里,智能设备…

    2022年9月6日
    5
  • StateMachine

    StateMachine

    2021年9月10日
    58
  • 漏洞扫描和渗透性测试_漏洞扫描软件有哪些

    漏洞扫描和渗透性测试_漏洞扫描软件有哪些目录1.nessus2.AWVS3.WPscan1.nessus1.Nessus软件是什么?如图,我们可以从百度百科得知:Nessus是全世界最多人使用的系统漏洞扫描与分析软件。总共有超过75,000个机构使用Nessus作为扫描该机构电脑系统的软件。2.Nessus软件的安装1.下载地址DownloadNessus|Tenable®https://www.tenable.com/downloads/nessus如图所示,这个是下载官网。我们以..

    2022年9月13日
    2
  • 【Github教程】史上最全github用法:github入门到精通

    【Github教程】史上最全github用法:github入门到精通

    2021年11月28日
    42
  • Cobbler实现CentOS自动安装

    Cobbler实现CentOS自动安装

    2021年9月15日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号