首页 > 编程问答 >有没有办法让用户输入 url 查询并使用单个函数过滤数据库?

有没有办法让用户输入 url 查询并使用单个函数过滤数据库?

时间:2024-07-22 12:46:59浏览次数:8  
标签:python rest django-rest-framework

我正在使用 Django Rest 框架和 PostgreSQL,构建一个返回本 NBA 赛季所有统计数据的 API。不是有一个函数来返回每个类别的统计信息,例如:

 @api_view(['GET'])
def sortByRebounds(request):
    """Returns all stats in the database sorted by rebounds per game"""
    string = Nba_stats.objects.values_list('name', 'team', 'rpg').order_by('rpg').reverse()
    return Response(string)

是否可以有一个函数能够根据用户在 url 中键入的内容来过滤和返回数据?

例如一个名为| 的函数||接受一个类别作为参数和一个 url sortBy ,用户可以在其中输入 "api/sortby/<str:category>/" 并接收有关篮板的数据,或 "api/sortby/rebounds" 并接收有关助攻的所有数据。 "api/sortby/assists" and receive everything on assists.


是的,可以使用单个函数根据 URL 查询参数过滤和返回数据。

以下是使用 Django REST framework 和 PostgreSQL 实现此功能的方法:

views.py

from rest_framework.decorators import api_view
from rest_framework.response import Response
from .models import Nba_stats

@api_view(['GET'])
def sort_by(request):
    """
    按给定类别返回所有统计数据,并按降序排序。
    """
    category = request.query_params.get('category')

    if not category:
        return Response({"error": "缺少 'category' 查询参数"}, status=400)

    valid_categories = ['rpg', 'apg', 'ppg', 'etc']  # 添加拥有的有效类别
    if category not in valid_categories:
        return Response({"error": f"'{category}' 不是有效的类别。 有效的类别是:{', '.join(valid_categories)}"}, status=400)

    stats = Nba_stats.objects.values_list('name', 'team', category).order_by(f'-{category}')
    return Response(stats)

urls.py

from django.urls import path
from . import views

urlpatterns = [
    path('api/sortby/', views.sort_by, name='sort_by'),
]

在此代码中:

  1. 我们创建了一个名为 sort_by 的单一视图函数。
  2. 我们使用 request.query_params.get('category') 从 URL 查询参数中提取 category
  3. 我们检查是否提供了类别,如果没有,则返回错误。
  4. 我们根据 category 参数动态构造排序字段 ( f'-{category}' ),以按降序排序。
  5. 我们使用提供的类别从 Nba_stats 模型中检索数据。
  6. 最后,我们以 JSON 形式返回排序后的统计数据。

现在,可以使用以下 URL 访问此 API:

  • 获取按篮板排序的数据: /api/sortby/?category=rpg
  • 获取按助攻排序的数据: /api/sortby/?category=apg
  • 获取按得分排序的数据: /api/sortby/?category=ppg

通过调整有效类别列表,可以根据数据库中的可用统计数据自定义此功能。 这提供了使用单个函数过滤不同类别的一个灵活且可扩展的解决方案。

标签:python,rest,django-rest-framework
From: 76447170

相关文章

  • Python:定期检测断开故障的USB设备并重新初始化实例
    我有一个USB设备,有时会通过USB端口发送串行数据。问题是设备出现故障,有时会无缘无故地断开连接并再次连接到电脑。问题不大,但在这些情况下我需要重新初始化serial.Serial(port)实例,这有点烦人。该设备没有可以从我那里收到的任何命令,我可以验证它是否已连接。我可以......
  • 【校招+社招】华为OD机试 - 拼接URL(Java、JavaScript、Python、C、C++)
    鱼弦:公众号【红尘灯塔】,CSDN博客专家、内容合伙人、新星导师、全栈领域优质创作者、51CTO(Top红人+专家博主)、github开源爱好者(go-zero源码二次开发、游戏后端架构https://github.com/Peakchen)算法概述URL拼接(URL拼接)是指将多个URL组件(方案、主机、端口、路径、查询参......
  • 使用 Google Colab 时,Python 包“datasets”从 virtualenv 目录“site-packages”中消
    我正在使用GoogleColab并尝试创建一个虚拟环境来工作。我的代码是:fromgoogle.colabimportdrivedrive.mount('/content/drive')!pipinstallvirtualenvmyenv_dir='/content/drive/MyDrive/virtual_env/'!virtualenv{myenv_dir}!chmod+x{myen......
  • Python 3 - openpyxl - 按名称迭代列
    使用openpyxl不按数字而是按列标题(ws第一行中的字符串值)迭代列的最简单方法是什么:如下所示:forcellinws.columns['revenue']:print(cell.value)不幸的是,openpyxl不直接支持像ws.columns['revenue']这样按列标题进行迭代。openpyxl......
  • Python selenium 网络抓取 recaptcha
    我想抓取一个网站,但在此之前有一个验证码,我什至使用api获取了数据,并且我还将其注入到网站中,因为网页没有提交按钮,我无法提交。流程是这样的,如果我解决同一网址中的验证码,隐藏的内容将被显示。但它并没有得到解决。我到处都找过了。我找不到解决方案。谁能帮我解决这个问题?......
  • Python 装饰器 详解+案例
    Python装饰器是一种特殊的函数,用于修改其他函数的功能。装饰器可以在不改变原函数代码的情况下,对函数进行增加、修改或者扩展功能。装饰器的语法形式是在函数定义前使用@符号,并在@后面加上装饰器的名称。装饰器函数接受被装饰函数作为参数,并返回一个修改后的函数。impo......
  • 如何在 vercel 部署中路由 python 和 typescript 无服务器函数
    我从一个带有Next.js和Typescript前端以及python后端的全栈应用程序开始。由于我们想在vercel上部署,因此我们将所有后端功能迁移到/api文件夹中的typescript函数中,可通过以下方式访问:fetch('api/**foldername**)问题是我有一个简单的pytorch模型,因此......
  • python中datetime模块
    datetime模块可以更方便的显示日期,并对日期进行计算。datetime模块中常用的类及其功能描述如下:datetime.datetime------>表示日期时间的类(常用)datetime.timedelta------>表示时间间隔的类(常用)datetime.date------>表示日期的类datetime.time------>表示时间的类datetime.......
  • Python - requests
    前言:介绍:安装及验证:使用:连续接口请求:传参方式: 前言:当你上班无聊的时候,你做什么,说实话有人让我写个requests的教程,教程我觉得网上已经有很多教程了,也很全面,我还是不要献丑了介绍:哎,我认为就是一个接口请求的仓库,不过requests属于第三方库,......
  • Python学习计划——2.4列表推导式(List Comprehensions)
    列表推导式是Python的一种简洁且强大的语法,用于生成新的列表。它可以用更少的代码、更清晰的方式来创建列表,特别是在处理简单的循环和条件操作时。1.基本语法列表推导式的基本语法如下:[expressionforiteminiterable]expression:表达式,计算结果用于生成列表的元素。ite......