共计 1356 个字符,预计需要花费 4 分钟才能阅读完成。
导读 | 这篇文章主要介绍了 Python 异常 ValueError 的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教 |
Python 异常 ValueError
ValueError: invalid literal for int() with base 10: '*'
试图将一个与数字无关的类型转化为整数,会抛出该异常。
>>> int("99 years ago.") | |
Traceback (most recent call last): | |
File "", line 1, in | |
ValueError: invalid literal for int() with base 10: '99 years ago.' |
规避方法:int 函数参数应该合法使用。int 函数使用传送门:Python 中的 int 函数使用
ValueError: too many values to unpack (expected 2)
试图遍历字典时同时遍历键和值。
demo = {"China": "Beijing", "Japan": "Tokyo"} | |
for k, v in demo: | |
print(k, v) | |
Traceback (most recent call last): | |
File "", line 1, in | |
ValueError: too many values to unpack (expected 2) |
Python 只允许对字典 key 的遍历,因此上面的遍历方式是错误的。
规避方法
方法一:使用 dict[key] 的方式同时获取 value
demo = {"China": "Beijing", "Japan": "Tokyo"} | |
for key in demo: | |
print(key, demo[key]) | |
China Beijing | |
Japan Tokyo |
方法二:使用 items 方法
demo = {"China": "Beijing", "Japan": "Tokyo", "the United States": "Washington D.C."} | |
for key, value in demo.items(): | |
print(key, value) | |
China Beijing | |
Japan Tokyo | |
the United States Washington D.C. | |
ValueError: binary mode doesn't take an encoding argument |
试图以二进制模式读取文件时指定编码方式。
with open("protoc-gen-go", "rb+", encoding="utf-8") as file: | |
data = file.read() | |
Traceback (most recent call last): | |
File "", line 1, in | |
ValueError: binary mode doesn't take an encoding argument |
规避方法:避免使用 encoding 关键字
with open("protoc-gen-go", "rb+") as file: | |
data = file.read(10) | |
data | |
b'\xcf\xfa\xed\xfe\x07\x00\x00\x01\x03\x00' |
正文完
星哥玩云-微信公众号
