Python 中 TypeError: can only concatenate str (not "int") to str 错误
当我们尝试连接字符串和整数时,会出现 Python“TypeError: can only concatenate str (not "int") to str”。 要解决该错误,请将 int
转换为字符串,例如 str(my_int)
连接字符串或将 str 转换为 int,例如 int(my_str)
添加数字。
下面是一个产生上述错误的示例代码
# ⛔️ TypeError: can only concatenate str (not "int") to str
result = 'hi' + 123
我们尝试使用加法
+
运算符连接字符串和导致错误的整数。
左侧和右侧的值需要是兼容的类型。
解决错误的一种方法是将整数转换为字符串。
result = 'hi' + str(123)
print(result) # 👉️ 'hi123'
我们将整数传递给 str()
类,并在连接两个字符串之前将其转换为字符串。
如果我们有一个包含在字符串和整数中的数字,则需要将字符串转换为整数(或浮点数)以将两个数字相加。
result = int('50') + 50
print(result) # 👉️ 100
我们将字符串传递给 int()
类以将其转换为整数。 请注意,如果需要将字符串转换为浮点数,也可以使用 float()
类。
重要提示
:如果我们使用input()
内置函数,则用户输入的所有值都会转换为字符串(甚至是数值)。
使用加法 +
运算符连接字符串的替代方法是使用格式化字符串文字。
str_1 = 'abc'
num_1 = 123
result = f'{str_1} {num_1} def'
print(result) # 👉️ 'abc 123 def'
格式化字符串文字
f-strings
让我们通过在字符串前加上 f 来在字符串中包含表达式。
确保将表达式用大括号括起来 - {expression}
。
如果我们不确定变量存储什么类型,请使用内置的 type()
类。
str_1 = 'abc'
print(type(str_1)) # <class 'str'>
print(isinstance(str_1, str)) # 👉️ True
num_1 = 123
print(type(num_1)) # <class 'int'>
print(isinstance(num_1, int)) # 👉️ True
类型类返回对象的类型。
使用内置的 input()
函数获取用户输入时,通常会发生该错误。
num = input('Enter your fav number: ')
print(num) # 👉️ '10'
print(type(num)) # 👉️ <class 'str'>
result = num + 100
# ⛔️ TypeError: can only concatenate str (not "int") to str
print(result)
输入函数将数据转换为字符串并返回。
即使用户输入一个数字,它也会在从
input()
返回之前转换为字符串。
如果需要将结果转换为数字,将其传递给 int()
(或 float()
)类。
num = input('Enter your fav number: ')
print(num) # 👉️ '10'
print(type(num)) # 👉️ <class 'str'>
# ✅ convert to int
result = int(num) + 100
print(result) # 👉️ 110
我们将从输入函数中得到的字符串转换回整数并将这两个数字相加。
我们用加法 +
运算符添加的值必须是兼容的类型,例如 一个浮点数和一个整数。
我们不能使用加法 +
运算符简单地添加一个字符串和一个整数,因为这会导致错误。
总结
当我们尝试连接字符串和整数时,会出现 Python“TypeError: can only concatenate str (not "int") to str”。 要解决该错误,请将 int 转换为字符串,例如 str(my_int)
连接字符串或将 str 转换为 int,例如 int(my_str)
添加数字。
相关文章
Python pandas.pivot_table() 函数
发布时间:2024/04/24 浏览次数:82 分类:Python
-
Python Pandas pivot_table()函数通过对数据进行汇总,避免了数据的重复。
在 Python 中将 Pandas 系列的日期时间转换为字符串
发布时间:2024/04/24 浏览次数:894 分类:Python
-
了解如何在 Python 中将 Pandas 系列日期时间转换为字符串
在 Python Pandas 中使用 str.split 将字符串拆分为两个列表列
发布时间:2024/04/24 浏览次数:1124 分类:Python
-
本教程介绍如何使用 pandas str.split() 函数将字符串拆分为两个列表列。
在 Pandas 中将 Timedelta 转换为 Int
发布时间:2024/04/23 浏览次数:231 分类:Python
-
可以使用 Pandas 中的 dt 属性将 timedelta 转换为整数。
Python 中的 Pandas 插入方法
发布时间:2024/04/23 浏览次数:112 分类:Python
-
本教程介绍了如何在 Pandas DataFrame 中使用 insert 方法在 DataFrame 中插入一列。
使用 Python 将 Pandas DataFrame 保存为 HTML
发布时间:2024/04/21 浏览次数:106 分类:Python
-
本教程演示如何将 Pandas DataFrame 转换为 Python 中的 HTML 表格。
如何将 Python 字典转换为 Pandas DataFrame
发布时间:2024/04/20 浏览次数:73 分类:Python
-
本教程演示如何将 python 字典转换为 Pandas DataFrame,例如使用 Pandas DataFrame 构造函数或 from_dict 方法。
如何在 Pandas 中将 DataFrame 列转换为日期时间
发布时间:2024/04/20 浏览次数:101 分类:Python
-
本文介绍如何将 Pandas DataFrame 列转换为 Python 日期时间。