解决Python/Flask中“TypeError: ‘float‘ object is not callable”错误

在部署使用Python和Flask框架编写的简单API时,遇到一个奇怪的错误“TypeError: ‘float’ object is not callable”。尽管变量类型应为int,但仍然出现此错误。即使尝试强制将变量类型转换为int,问题仍然存在。
在这里插入图片描述

2、解决方案:
此错误通常是由将变量类型分配为float类型引起的,导致无法访问range()内置函数。为了解决此问题,可以将range变量声明为int类型,如下所示:

if (lng != None) and (lat != None):
    range = int(0.1)

另外,代码中还存在一些其他问题:

  1. 将float类型的值分配给int类型的变量:

    price_min = request.args.get('price_min',default=None, type=float)
    price_max = request.args.get('price_max',default=None, type=float)
    
    rooms_min = request.args.get('rooms_min',default=None, type=float)
    rooms_max = request.args.get('rooms_max',default=None, type=float)
    

    为了避免此问题,应将type参数设置为int,如下所示:

    price_min = request.args.get('price_min',default=None, type=int)
    price_max = request.args.get('price_max',default=None, type=int)
    
    rooms_min = request.args.get('rooms_min',default=None, type=int)
    rooms_max = request.args.get('rooms_max',default=None, type=int)
    
  2. 在字符串连接中使用int变量时没有将变量转换为字符串:

    query = query + "," + str(counter + 6)
    

    为了解决此问题,应将int变量转换为字符串,如下所示:

    query = query + "," + str(str(counter + 6))
    

经过以上修改,代码应该可以正常运行,不会再出现“TypeError: ‘float’ object is not callable”错误。

修改后的代码示例:

def closest_point():
    lng = request.args.get('lng', default=None, type=float)
    lat = request.args.get('lat', default=None, type=float)

    price_min = request.args.get('price_min', default=None, type=int)
    price_max = request.args.get('price_max', default=None, type=int)

    rooms_min = request.args.get('rooms_min', default=None, type=int)
    rooms_max = request.args.get('rooms_max', default=None, type=int)

    if (lng != None) and (lat != None):
        range = int(0.1)
        lng_min = lng - range
        lng_max = lng + range
        lat_min = lat - range
        lat_max = lat + range

        cur = g.db.cursor()
        query = "SELECT id, link, price, longitude, latitude FROM " + DATABASE_TABLE_NAME + " WHERE latitude >= " + str(lat_min) + " AND latitude <= " + str(lat_max) + " AND longitude >= " + str(lng_min) + " AND longitude <= " + str(lng_max)

        # I always have 5 basic parameters to group by. I count number of additional parameters to know how many to add
        additional_params_count = 0
        if price_min:
            query = query + " AND price >= " + str(price_min)
            additional_params_count = additional_params_count + 1
        query = query + "GROUP BY 1,2,3,4,5"
        for counter in range(0, additional_params_count):
            query = query + "," + str(str(counter + 6))
        query = query + ";"
        cur.execute(query)
        columns = [desc[0] for desc in cur.description]
        rows = cur.fetchall()
        flats_json = []
        for row in rows:
            flats_json.append(dict((k, str(v)) for k, v in zip(columns, row)))
        response_body = str(rows)
        return json.dumps(flats_json)
    else:
        return "One of lng or lat parameters missing"
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TypeError: 'ImmutableMultiDict' object is not callable 是一个常见的错误,通常在使用Flask框架时出现。这个错误的原因是你尝试将一个不可调用的对象作为函数进行调用。 解决这个问题的方法是检查你的代码,确保你没有将一个不可调用的对象作为函数进行调用。具体来说,你可以检查以下几个方面: 1. 检查你的代码是否有类似于函数调用的语句,例如在函数名后面加上了括号。确保你正在调用的对象是可调用的,例如函数、方法或可调用的类。 2. 检查你的代码是否有命名冲突。有时候,你可能会意外地将一个变量名与一个函数名或方法名重复,导致无法正确调用函数。 3. 检查你的代码是否有语法错误或其他错误。有时候,一个语法错误或其他错误可能会导致解释器无法正确解析你的代码,从而出现这个错误。 下面是一个示例代码,演示了如何避免出现TypeError: 'ImmutableMultiDict' object is not callable错误: ```python from flask import Flask, request app = Flask(__name__) @app.route('/example', methods=['POST']) def example(): data = request.form.get('data') # 获取表单数据 # 进行其他操作 return 'Success' if __name__ == '__main__': app.run() ``` 在这个示例,我们使用Flask框架创建了一个简单的应用程序,并定义了一个POST请求的路由。在路由处理函数,我们使用`request.form.get()`方法获取表单数据,而不是直接调用`request.form()`,从而避免了TypeError错误

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值