ChatGPT解决这个技术问题 Extra ChatGPT

如何将字符串解析为浮点数或整数?

如何将 str 转换为浮点数? “545.2222”→ 545.2222

如何将 str 转换为 int? “31”→31

作为一般规则,如果您在 Python 中有一个对象,并且想要将该类型的对象转换为,请对其调用 type(my_object)。结果通常可以作为函数调用来进行转换。例如 type(100) 结果为 int,因此您可以调用 int(my_object) 尝试将 my_object 转换为整数。这并不总是有效,但在编码时是一个很好的“初步猜测”。
int(x) if int(x) == float(x) else float(x)
@tcpaiva ValueError: invalid literal for int() with base 10: '1.5'
int(x) if int(float(x)) == float(x) else float(x)

H
Harley Holcombe
>>> a = "545.2222"
>>> float(a)
545.22220000000004
>>> int(float(a))
545

只是想知道为什么最后会有'04'?为什么不简单地“00”?我当前的python版本也没有'04'。
@MangatRaiModi 浮点数本质上不适合表示小数。有关详细信息,请参阅stackoverflow.com/q/21895756/931277
为什么不是简单的 int(a) 而是 int(float(a))
int(a) 将给出字符串不是有效整数的错误:ValueError: invalid literal for int() with base 10: '545.222',但从 float 转换为 int 是受支持的转换。
如果您想安全起见,您应该处理 ValueError
E
Eric Leschinski

检查字符串是否为浮点数的 Python 方法:

def is_float(value):
  try:
    float(value)
    return True
  except:
    return False

此函数的更长更准确的名称可能是:is_convertible_to_float(value)

Python 中什么是浮点数,什么不是浮点数可能会让你感到惊讶:

val                   is_float(val) Note
--------------------  ----------   --------------------------------
""                    False        Blank string
"127"                 True         Passed string
True                  True         Pure sweet Truth
"True"                False        Vile contemptible lie
False                 True         So false it becomes true
"123.456"             True         Decimal
"      -127    "      True         Spaces trimmed
"\t\n12\r\n"          True         whitespace ignored
"NaN"                 True         Not a number
"NaNanananaBATMAN"    False        I am Batman
"-iNF"                True         Negative infinity
"123.E4"              True         Exponential notation
".1"                  True         mantissa only
"1,234"               False        Commas gtfo
u'\x30'               True         Unicode is fine.
"NULL"                False        Null is not special
0x3fade               True         Hexadecimal
"6e7777777777777"     True         Shrunk to infinity
"1.797693e+308"       True         This is max value
"infinity"            True         Same as inf
"infinityandBEYOND"   False        Extra characters wreck it
"12.34.56"            False        Only one dot allowed
u'四'                 False        Japanese '4' is not a float.
"#56"                 False        Pound sign
"56%"                 False        Percent of what?
"0E0"                 True         Exponential, move dot 0 places
0**0                  True         0___0  Exponentiation
"-5e-5"               True         Raise to a negative number
"+1e1"                True         Plus is OK with exponent
"+1e1^5"              False        Fancy exponent not interpreted
"+1e1.3"              False        No decimals in exponent
"-+1"                 False        Make up your mind
"(1)"                 False        Parenthesis is bad

你以为你知道数字是什么?你没有你想的那么好!没有什么大惊喜。

不要在生命攸关的软件上使用此代码!

以这种方式捕获广泛的异常,杀死金丝雀并吞噬异常会产生一个很小的机会,即作为字符串的有效浮点数将返回 false。 float(...) 行代码可能由于与字符串内容无关的一千个原因中的任何一个而失败。但是,如果您正在使用 Python 之类的鸭式原型语言编写对生命至关重要的软件,那么您将遇到更大的问题。


所以 true 变为 1,我认为是从 C++ 继承的
我在 2014 年发布了这个答案。多年来,中文 4UTF-8 字形一直在发生变化,这取决于 stackoverflow 开发人员如何在他们的 microsoft toolstack 上更改其字符编码方案。多年来,随着新的转换方案主张其新的意识形态,看到它翻转是一种好奇心。但是,是的,东方数字的任何 UTF-8 字形都不是 Python 浮点数。巴津加。
除了如此广泛的例外,怎么能如此赞成?
无法转换中间有空格的所有内容,例如 "- 12.3""45 e6"
此 except 子句应限制为 TypeError, ValueError
D
David Jones
def num(s):
    try:
        return int(s)
    except ValueError:
        return float(s)

implicit 混合浮点数/整数可能会导致细微的错误,因为在使用浮点数时可能会损失精度或导致浮点数/整数上的 / 运算符的不同结果。根据上下文,最好返回 int 或 float,而不是两者。
@JFSebastian您是完全正确的,但是有时您希望输入来指示它将是哪一个。让输入决定哪一个可以很好地使用鸭式打字。
您可以嵌套另一个 try 以在它不可转换为浮动时引发异常。
s = u'\u0000' 失败
@iBug 好主意!我建议将 ValueError 放入相应的 except 中:P
S
Stefano

这是另一种值得在这里提及的方法,ast.literal_eval

这可用于安全地评估来自不受信任来源的包含 Python 表达式的字符串,而无需自己解析值。

也就是说,一个安全的“评估”

>>> import ast
>>> ast.literal_eval("545.2222")
545.2222
>>> ast.literal_eval("31")
31

不是解决问题的好方法。它在 Python 2 中运行良好,但在 Python 3 中会发生以下情况:python >>> import ast >>> ast.literal_eval('1-800-555-1212') -2566 >>> 为了澄清为什么这是一个问题,如果您希望它不考虑电话号码并且不假定它们是数学表达式,那么这种方法不适合您.
@royce3 是的,这是一个很好的观点,用户应该小心。该行为最初是为了解决复杂文字解析的一些问题而修改的。这可能是 ast.literal_eval 中的一个错误,并且已在 here 中讨论过。
@royce3 作为记录,在 Python 3 中,ast 不会再将该电话号码直接评估为 -2566。它在 Python 3.7 changelog 中:ast.literal_eval() 现在更严格了。不再允许任意数字的加减法。 (由 Serhiy Storchaka 在 bpo-31778 中提供)
M
Mark Chackerian

本地化和逗号

您应该考虑在数字的字符串表示中使用逗号的可能性,例如 float("545,545.2222") 会引发异常。相反,使用 locale 中的方法将字符串转换为数字并正确解释逗号。一旦为所需的数字约定设置了语言环境,locale.atof 方法就会一步转换为浮点数。

示例 1——美国数字约定

在美国和英国,逗号可以用作千位分隔符。在此使用美国语言环境的示例中,逗号作为分隔符被正确处理:

>>> import locale
>>> a = u'545,545.2222'
>>> locale.setlocale(locale.LC_ALL, 'en_US.UTF-8')
'en_US.UTF-8'
>>> locale.atof(a)
545545.2222
>>> int(locale.atof(a))
545545
>>>

示例 2——欧洲号码约定

majority of countries of the world 中,逗号用于小数点而不是句点。在此使用法语语言环境的示例中,逗号被正确处理为小数点:

>>> import locale
>>> b = u'545,2222'
>>> locale.setlocale(locale.LC_ALL, 'fr_FR')
'fr_FR'
>>> locale.atof(b)
545.2222

方法 locale.atoi 也可用,但参数应为整数。


当您知道是否应该返回 float 或 int 时,这似乎是一个理想的解决方案,但是只有在传递了 int 的情况下,如何才能让它返回 int 呢?例如,当我真正想要 1 时,x = '1'; locale.atof(x) 返回 1.0
使用 Dino 的方法,我想答案应该是这样的:locale.atof(x) if locale.localeconv().get('decimal_point') in x else locale.atoi(x)
我建议使用上面的 Javier 方法(尝试包装 locale.atoi 并在异常情况下使用 locale.atof - 它可能更具可读性。
S
S.Lott
float(x) if '.' in x else int(x)

注意:处理作为字符串传递的金额时要小心,因为某些国家/地区使用“,”作为小数分隔符
@Emile:我不会将“2e-3”称为“极端情况”。这个答案刚刚被打破。
@BenG 不要把钱当作浮动来操纵。那是自找麻烦。用十进制来赚钱! (但您对“,”的评论仍然有效且重要)
不要忘记“不是数字”(NaN)和 +/- 无穷大也是有效的浮点值。所以 float("nan") 是一个完全有效的浮点值,上面的答案根本无法捕捉到
很容易被 IP 地址破解 - 192.168.0.1;或"This is not a good approach. :)"
S
SethMMorton

如果您不反对第三方模块,可以查看 fastnumbers 模块。它提供了一个名为 fast_real 的函数,它完全符合这个问题的要求,并且比纯 Python 实现更快:

>>> from fastnumbers import fast_real
>>> fast_real("545.2222")
545.2222
>>> type(fast_real("545.2222"))
float
>>> fast_real("31")
31
>>> type(fast_real("31"))
int

P
Peter Mortensen

用户 codelogic 和 harley 是正确的,但请记住,如果您知道字符串是整数(例如 545),您可以调用 int("545") 而不首先转换为浮点数。

如果您的字符串在列表中,您也可以使用 map 函数。

>>> x = ["545.0", "545.6", "999.2"]
>>> map(float, x)
[545.0, 545.60000000000002, 999.20000000000005]
>>>

只有当它们都是同一类型时才好。


R
Russia Must Remove Putin

在 Python 中,如何将像“545.2222”这样的数字字符串解析为其对应的浮点值 542.2222?或者将字符串“31”解析为整数 31?我只想知道如何将浮点字符串解析为浮点数,以及(单独)将 int 字符串解析为 int。

您要求单独执行这些操作很好。如果您将它们混合在一起,您可能会在以后遇到问题。简单的答案是:

"545.2222" 浮动:

>>> float("545.2222")
545.2222

"31" 转为整数:

>>> int("31")
31

其他转换、整数与字符串和文字之间的转换:

各种基数的转换,您应该提前知道基数(默认为 10)。请注意,您可以在它们前面加上 Python 对其文字的期望(见下文)或删除前缀:

>>> int("0b11111", 2)
31
>>> int("11111", 2)
31
>>> int('0o37', 8)
31
>>> int('37', 8)
31
>>> int('0x1f', 16)
31
>>> int('1f', 16)
31

如果您事先不知道基数,但您确实知道它们将具有正确的前缀,那么如果您将 0 作为基数,Python 可以为您推断:

>>> int("0b11111", 0)
31
>>> int('0o37', 0)
31
>>> int('0x1f', 0)
31

来自其他基数的非十进制(即整数)文字

但是,如果您的动机是让您自己的代码清楚地表示硬编码的特定值,那么您可能不需要从基础转换 - 您可以让 Python 使用正确的语法自动为您完成。

您可以使用 apropos 前缀通过 the following literals 自动转换为整数。这些对 Python 2 和 3 有效:

二进制,前缀 0b

>>> 0b11111
31

八进制,前缀 0o

>>> 0o37
31

十六进制,前缀 0x

>>> 0x1f
31

这在描述二进制标志、代码中的文件权限或颜色的十六进制值时很有用 - 例如,请注意没有引号:

>>> 0b10101 # binary flags
21
>>> 0o755 # read, write, execute perms for owner, read & ex for group & others
493
>>> 0xffffff # the color, white, max values for red, green, and blue
16777215

使模棱两可的 Python 2 八进制与 Python 3 兼容

如果你看到一个以 0 开头的整数,在 Python 2 中,这是(不推荐使用的)八进制语法。

>>> 037
31

这很糟糕,因为它看起来应该是 37。所以在 Python 3 中,它现在引发了一个 SyntaxError

>>> 037
  File "<stdin>", line 1
    037
      ^
SyntaxError: invalid token

将您的 Python 2 八进制转换为可在 2 和 3 中使用 0o 前缀的八进制:

>>> 0o37
31

P
Peter Mortensen

这个问题似乎有点老了。但是让我建议一个函数 parseStr,它可以做类似的事情,即返回整数或浮点数,如果给定的 ASCII 字符串不能转换为它们中的任何一个,它就会原封不动地返回它。当然可以调整代码以仅执行您想要的操作:

   >>> import string
   >>> parseStr = lambda x: x.isalpha() and x or x.isdigit() and \
   ...                      int(x) or x.isalnum() and x or \
   ...                      len(set(string.punctuation).intersection(x)) == 1 and \
   ...                      x.count('.') == 1 and float(x) or x
   >>> parseStr('123')
   123
   >>> parseStr('123.3')
   123.3
   >>> parseStr('3HC1')
   '3HC1'
   >>> parseStr('12.e5')
   1200000.0
   >>> parseStr('12$5')
   '12$5'
   >>> parseStr('12.2.2')
   '12.2.2'

1e3 在 python 中是一个数字,但根据您的代码是一个字符串。
我更喜欢这个答案。
c
codelogic

float("545.2222")int(float("545.2222"))


如果您的字符串恰好是“0”或“0.0”,这将为您提供一个浮点对象,而不是它为其他有效数字提供的 int。
P
Peter Mortensen

YAML 解析器可以帮助您确定您的字符串是什么数据类型。使用 yaml.load(),然后您可以使用 type(result) 来测试类型:

>>> import yaml

>>> a = "545.2222"
>>> result = yaml.load(a)
>>> result
545.22220000000004
>>> type(result)
<type 'float'>

>>> b = "31"
>>> result = yaml.load(b)
>>> result
31
>>> type(result)
<type 'int'>

>>> c = "HI"
>>> result = yaml.load(c)
>>> result
'HI'
>>> type(result)
<type 'str'>

这是一个很好的答案(或 json 或任何您喜欢的答案):我们都认识到正确的转换并非易事。所以找一个被广泛采用的库来为你管理这个。 :)
JSON 可以很好地工作,但如果传递了一个字符串,它只会引发 TypeError,因此需要一些自定义处理或预检查以避免一些尝试。像我一样一些正则表达式:stackoverflow.com/a/69790897/1236083
S
Shameem

我为此使用此功能

import ast

def parse_str(s):
   try:
      return ast.literal_eval(str(s))
   except:
      return

它将字符串转换为其类型

value = parse_str('1')  # Returns Integer
value = parse_str('1.5')  # Returns Float

请注意,parse_str(' 1')(带有空格)将返回 None,而不是 1
T
Totoro
def get_int_or_float(v):
    number_as_float = float(v)
    number_as_int = int(number_as_float)
    return number_as_int if number_as_float == number_as_int else number_as_float

如果您在那里什么都不做,为什么要在 except 部分加注? float() 会为你筹集资金。
你是对的,我想我是从一个我提出特定异常的功能中复制和粘贴的。将编辑。谢谢
这将尝试解析字符串并根据字符串表示的内容返回 intfloat。它可能会引发解析异常或[有一些意外行为][1]。
G
Georgy
def num(s):
    """num(s)
    num(3),num(3.7)-->3
    num('3')-->3, num('3.7')-->3.7
    num('3,700')-->ValueError
    num('3a'),num('a3'),-->ValueError
    num('3e4') --> 30000.0
    """
    try:
        return int(s)
    except ValueError:
        try:
            return float(s)
        except ValueError:
            raise ValueError('argument is not a string of number')

G
Guy Avraham

您需要考虑四舍五入才能正确执行此操作。

即 - int(5.1) => 5 int(5.6) => 5 -- 错误,应该是 6 所以我们做 int(5.6 + 0.5) => 6

def convert(n):
    try:
        return int(n)
    except ValueError:
        return float(n + 0.5)

好点子。但是,这会导致通货膨胀,因此 Python 3other modern languages 使用银行家四舍五入。
这个答案是错误的(如最初所写)。它混淆了 intfloat 两种情况。当 n 是一个字符串时,它会给出一个例外,正如 OP 所希望的那样。也许您的意思是:需要 int 结果时,应在转换为浮点数后完成 round。如果函数应该总是返回一个 int,那么你就不需要 except 部分——整个函数体可以是 int(round(float(input)))。如果函数应该尽可能返回 int,否则返回 float,那么 javier 的原始解决方案是正确的!
ValueError:无法将字符串转换为浮点数
S
Sławomir Lenart

我很惊讶没有人提到正则表达式,因为有时必须在转换为数字之前准备好字符串并对其进行规范化

import re
def parseNumber(value, as_int=False):
    try:
        number = float(re.sub('[^.\-\d]', '', value))
        if as_int:
            return int(number + 0.5)
        else:
            return number
    except ValueError:
        return float('nan')  # or None if you wish

用法:

parseNumber('13,345')
> 13345.0

parseNumber('- 123 000')
> -123000.0

parseNumber('99999\n')
> 99999.0

顺便说一句,可以验证您是否有号码:

import numbers
def is_number(value):
    return isinstance(value, numbers.Number)
    # will work with int, float, long, Decimal

C
Cybernetic

将您的字符串传递给此函数:

def string_to_number(str):
  if("." in str):
    try:
      res = float(str)
    except:
      res = str  
  elif(str.isdigit()):
    res = int(str)
  else:
    res = str
  return(res)

它将根据传递的内容返回 int、float 或 string。

一个 int 的字符串

print(type(string_to_number("124")))
<class 'int'>

浮点数的字符串

print(type(string_to_number("12.4")))
<class 'float'>

作为字符串的字符串

print(type(string_to_number("hello")))
<class 'str'>

看起来像浮点数的字符串

print(type(string_to_number("hel.lo")))
<class 'str'>

在查看名称 string_to_number 时,我不希望它返回一个字符串。如果无法解析输入,我希望它会引发异常
我不认为一个名为 string_to_number 的方法不应该返回一个字符串是一个有争议的观点。我投了反对票,因为这个函数要么名字不好,要么它的行为是错误的。此外,没有必要被动攻击。我们可以用专业的方式谈论这个
U
U12-Forward

您可以使用 json.loads

>>> import json
>>> json.loads('123.456')
123.456
>>> type(_)
<class 'float'>
>>> 

如您所见,它变成了一种 float


G
Guy Avraham

要在 Python 中使用 typecast 类型的构造函数,将字符串(或您尝试转换的任何值)作为参数传递。

例如:

>>>float("23.333")
   23.333

在幕后,Python 正在调用 objects __float__ 方法,该方法应返回参数的浮点表示。这特别强大,因为您可以使用 __float__ 方法定义自己的类型(使用类),以便可以使用 float(myobject) 将其转换为浮点数。


s
shrewmouse

处理十六进制、八进制、二进制、十进制和浮点数

该解决方案将处理数字的所有字符串约定(我所知道的一切)。

def to_number(n):
    ''' Convert any number representation to a number 
    This covers: float, decimal, hex, and octal numbers.
    '''

    try:
        return int(str(n), 0)
    except:
        try:
            # python 3 doesn't accept "010" as a valid octal.  You must use the
            # '0o' prefix
            return int('0o' + n, 0)
        except:
            return float(n)

这个测试用例输出说明了我在说什么。

======================== CAPTURED OUTPUT =========================
to_number(3735928559)   = 3735928559 == 3735928559
to_number("0xFEEDFACE") = 4277009102 == 4277009102
to_number("0x0")        =          0 ==          0
to_number(100)          =        100 ==        100
to_number("42")         =         42 ==         42
to_number(8)            =          8 ==          8
to_number("0o20")       =         16 ==         16
to_number("020")        =         16 ==         16
to_number(3.14)         =       3.14 ==       3.14
to_number("2.72")       =       2.72 ==       2.72
to_number("1e3")        =     1000.0 ==       1000
to_number(0.001)        =      0.001 ==      0.001
to_number("0xA")        =         10 ==         10
to_number("012")        =         10 ==         10
to_number("0o12")       =         10 ==         10
to_number("0b01010")    =         10 ==         10
to_number("10")         =         10 ==         10
to_number("10.0")       =       10.0 ==         10
to_number("1e1")        =       10.0 ==         10

这是测试:

class test_to_number(unittest.TestCase):

    def test_hex(self):
        # All of the following should be converted to an integer
        #
        values = [

                 #          HEX
                 # ----------------------
                 # Input     |   Expected
                 # ----------------------
                (0xDEADBEEF  , 3735928559), # Hex
                ("0xFEEDFACE", 4277009102), # Hex
                ("0x0"       ,          0), # Hex

                 #        Decimals
                 # ----------------------
                 # Input     |   Expected
                 # ----------------------
                (100         ,        100), # Decimal
                ("42"        ,         42), # Decimal
            ]



        values += [
                 #        Octals
                 # ----------------------
                 # Input     |   Expected
                 # ----------------------
                (0o10        ,          8), # Octal
                ("0o20"      ,         16), # Octal
                ("020"       ,         16), # Octal
            ]


        values += [
                 #        Floats
                 # ----------------------
                 # Input     |   Expected
                 # ----------------------
                (3.14        ,       3.14), # Float
                ("2.72"      ,       2.72), # Float
                ("1e3"       ,       1000), # Float
                (1e-3        ,      0.001), # Float
            ]

        values += [
                 #        All ints
                 # ----------------------
                 # Input     |   Expected
                 # ----------------------
                ("0xA"       ,         10), 
                ("012"       ,         10), 
                ("0o12"      ,         10), 
                ("0b01010"   ,         10), 
                ("10"        ,         10), 
                ("10.0"      ,         10), 
                ("1e1"       ,         10), 
            ]

        for _input, expected in values:
            value = to_number(_input)

            if isinstance(_input, str):
                cmd = 'to_number("{}")'.format(_input)
            else:
                cmd = 'to_number({})'.format(_input)

            print("{:23} = {:10} == {:10}".format(cmd, value, expected))
            self.assertEqual(value, expected)

ValueError:无法将字符串转换为浮点数
b
bougui
a = int(float(a)) if int(float(a)) == float(a) else float(a)

C
Community

这是https://stackoverflow.com/a/33017514/5973334的修正版

这将尝试解析字符串并根据字符串表示的内容返回 intfloat。它可能会引发解析异常或have some unexpected behaviour

  def get_int_or_float(v):
        number_as_float = float(v)
        number_as_int = int(number_as_float)
        return number_as_int if number_as_float == number_as_int else 
        number_as_float

S
Sameh Farouk

这是一个老问题,已经得到了很多答案。但是,如果您正在处理混合整数和浮点数并且想要一种一致的方式来处理您的混合数据,这是我使用正确文档字符串的解决方案:

def parse_num(candidate):
    """parse string to number if possible
    work equally well with negative and positive numbers, integers and floats.

    Args:
        candidate (str): string to convert

    Returns:
        float | int | None: float or int if possible otherwise None
    """
    try:
        float_value = float(candidate)
    except ValueError:
        return None

    # optional part if you prefer int to float when decimal part is 0 
    if float_value.is_integer():
        return int(float_value)
    # end of the optional part

    return float_value

# test
candidates = ['34.77', '-13', 'jh', '8990', '76_3234_54']
res_list = list(map(parse_num, candidates))
print('Before:')
print(candidates)
print('After:')
print(res_list)

输出:

Before:
['34.77', '-13', 'jh', '8990', '76_3234_54']
After:
[34.77, -13, None, 8990, 76323454]

P
Peter Mortensen

利用:

def num(s):
    try:
        for each in s:
            yield int(each)
    except ValueError:
        yield float(each)
a = num(["123.55","345","44"])
print a.next()
print a.next()

这是我能想到的最 Pythonic 的方式。


生成器在第一次解释 float 后停止。 trycatch 块可能应该在 for 循环内。
P
Peter Mortensen

利用:

>>> str_float = "545.2222"
>>> float(str_float)
545.2222
>>> type(_) # Check its type
<type 'float'>

>>> str_int = "31"
>>> int(str_int)
31
>>> type(_) # Check its type
<type 'int'>

A
Abhishek Bhatia

这是一个函数,它将根据提供的实际字符串 看起来像 int 还是 float,将任何 object(不仅仅是 str)转换为 intfloat .此外,如果它是同时具有 __float__int__ 方法的对象,则默认使用 __float__

def conv_to_num(x, num_type='asis'):
    '''Converts an object to a number if possible.
    num_type: int, float, 'asis'
    Defaults to floating point in case of ambiguity.
    '''
    import numbers

    is_num, is_str, is_other = [False]*3

    if isinstance(x, numbers.Number):
        is_num = True
    elif isinstance(x, str):
        is_str = True

    is_other = not any([is_num, is_str])

    if is_num:
        res = x
    elif is_str:
        is_float, is_int, is_char = [False]*3
        try:
            res = float(x)
            if '.' in x:
                is_float = True
            else:
                is_int = True
        except ValueError:
            res = x
            is_char = True

    else:
        if num_type == 'asis':
            funcs = [int, float]
        else:
            funcs = [num_type]

        for func in funcs:
            try:
                res = func(x)
                break
            except TypeError:
                continue
        else:
            res = x

S
SHR

通过使用 int 和 float 方法,我们可以将字符串转换为整数和浮点数。

s="45.8"
print(float(s))

y='67'
print(int(y))

这个答案没有添加任何新内容。例如,请参阅 this answer,它提供了相同的信息及更多信息。
m
mamal

对于数字和字符一起:

string_for_int = "498 results should get"
string_for_float = "498.45645765 results should get"

首先导入重新:

 import re

 #for get integer part:
 print(int(re.search(r'\d+', string_for_int).group())) #498

 #for get float part:
 print(float(re.search(r'\d+\.\d+', string_for_float).group())) #498.45645765

对于简单的模型:

value1 = "10"
value2 = "10.2"
print(int(value1)) #10
print(float(value2)) #10.2

P
Peter Mortensen

这是对您的问题的另一种解释(提示:含糊不清)。您可能正在寻找这样的东西:

def parseIntOrFloat( aString ):
    return eval( aString )

它像这样工作......

>>> parseIntOrFloat("545.2222")
545.22220000000004
>>> parseIntOrFloat("545")
545

理论上,存在注入漏洞。例如,该字符串可以是 "import os; os.abort()"。然而,在没有任何关于字符串来自何处的背景的情况下,这种可能性是理论上的推测。由于问题含糊不清,因此根本不清楚该漏洞是否真的存在。


即使他的输入是 100% 安全的,eval() 的速度也是 try: int(s) except: float(s) 的 3 倍多。
好吧,eval 是不好的做法(你必须知道,因为你有 310k 的声誉)