int()转换失败抛ValueError;应使用try/except捕获并处理,避免用int(float())掩盖精度问题。

int() 转换失败时抛什么错?怎么安全处理?
int() 遇到无法解析的字符串(比如 "12.5"、"abc"、空字符串 "")会直接抛 ValueError,不是 TypeError。它只认纯整数形式的字符串(可带正负号),不接受小数点、科学计数法或空白以外的字符。
- 用
try/except捕获ValueError是最稳妥的做法 - 不要依赖
if isinstance(x, str)就直接转——类型检查不能替代内容校验 -
int(float("12.5"))看似能绕过,但会先截断再转,容易掩盖精度丢失问题
try:
n = int(user_input)
except ValueError:
n = 0 # 或抛自定义错误、返回 Nonefloat() 转字符串时为啥出现 0.1 + 0.2 != 0.3?
这不是转换问题,是浮点数在二进制下无法精确表示十进制小数导致的固有误差。float("0.1") 存进去的就不是数学意义上的 0.1,后续所有运算都基于这个近似值。
-
str(0.1 + 0.2)输出"0.30000000000000004",是因为 Python 默认显示足够位数来区分相邻浮点数 - 如果需要可控输出,用
f"{x:.1f}"或round(x, 1),但注意round()也不改变底层值 - 涉及金额等必须精确的场景,别用
float,改用decimal.Decimal
from decimal import Decimal
Decimal("0.1") + Decimal("0.2") == Decimal("0.3") # Truestr() 转对象时调用的是 __str__ 还是 __repr__?
str(x) 优先调用 x.<strong>str</strong>();如果没定义或返回非字符串,才 fallback 到 x.<strong>repr</strong>()。但两者语义不同:<strong>str</strong> 面向用户,<strong>repr</strong> 面向开发者(最好能 eval 出原对象)。
- 自定义类里只实现
<strong>repr</strong>是底线,否则str(obj)可能返回难读的"<<strong>main</strong>.A object at 0x...>" - 不要让
<strong>str</strong>返回空字符串或纯空格,这会让日志、调试失去关键信息 -
print(x)内部就是调str(x),所以它的输出质量取决于你写的<strong>str</strong>
class Point:
def __init__(self, x, y):
self.x, self.y = x, y
def __str__(self):
return f"({self.x}, {self.y})" # 用户友好
def __repr__(self):
return f"Point({self.x!r}, {self.y!r})" # 开发者友好隐式转换在哪偷偷发生?哪些地方绝对不能依赖?
Python 的隐式转换极少,只有少数几个地方:布尔上下文(if x:)、数字混合运算(3 + 4.0 → float)、print() 参数自动转 str。但它不会在赋值、函数参数、比较(== 除外)、容器操作中自动强转。
立即学习“Python免费学习笔记(深入)”;
-
[1, 2] + "3"报TypeError,不会把字符串转成列表 -
dict.get("key", 0)中的默认值 0 不会自动转成字符串,哪怕 key 对应的是字符串 -
1 == True是True(因为bool是int子类),但这是特例,不是通用转换规则
最容易被忽略的是:函数参数签名和类型提示(如 def f(x: int):)完全不影响运行时行为,f("123") 依然能跑,只是可能在后续计算中崩。类型检查靠 mypy,不是靠 Python 自己。









