Django之无名分组,有名分组

在Django 2.0版本之前,在urls,py文件中,用url设定视图函数

urlpatterns = [
  url(r'login/',views.login),
]

其中第一个参数是正则匹配,如下代码,输入http://127.0.0.1:8000/login,出现的是login页面,但是输入login2,出现的还是login页面,这是因为Django会将匹配成功的返回,不会继续往下匹配

urlpatterns = [
  url(r'login',views.login),
  url(r'login2',views.login2),
]

所以为了避免上面这种情况,可以在第一个参数加上正则表达式

urlpatterns = [
  url(r'^login/$',views.login),
  url(r'^login2/$',views.login2),
]

^号限定开头,$限定结尾,' / '为匹配机制,比如第一次输入:http://127.0.0.1:8000/login,没有匹配成功,系统会自动加上‘/‘再进行一次匹配

这样就可以写出首页和尾页(尾页是指找不到对应页面时打开的页面,俗称404)

urlpatterns = [
  url(r'^$',views.home), #这是首页
  url(r'',views.error) #这是尾页
]

同样的既然可以进行正则匹配,那么就可以写更多的正则语法:

urlpatterns = [
  url(r'^login/[0-9]{4}$',views.login),
]

类似上面写出的正则,就是login/ 后面随意加上4位数字都可以访问login页面

同样的正则还有分组的概念,但是在Django中把分组分为两种:无名分组和有名分组

无名分组

urlpatterns = [
  url(r'^login/([0-9]{4})$',views.login),
]

在普通的正则匹配中加上()就是无名分组,那么这样有什么意义呢?

首先在后端的views上,会得到一个分组的参数,以上面代码为例,那么views.login函数的参数除了request,还需要添加一个参数(名字随意),进行几次分组那么就需要多添加几次参数

进入view页面,其中xxx的名字是随意的,传进来的分组的数据例如我输入的网址是:login/222,那么xxx的值为222

def login(request,xxx):
    print(xxx)

有名分组:

有名分组其实就是在无名的分组的基础上加上了名字

urlpatterns = [
  url(r'^login/(?P<year>[0-9]{4})$',views.login),
]

语法为:(?P<名字> 正则表达式),就是在无名分组的括号里面加上了?P<名字>,注意其中P为大写

既然有了名字,那么在views页面就不能给函数传递随意的参数了:

def login(request,year):
    print(year)

第二个参数year是urls页面命名的名字:

如果名字不一样则会报错

 

这里有一个坑,既然分组有有名分组和无名分组,那么能不能一起使用?

答:不行,别问,问就是不行

 

转载于:https://www.cnblogs.com/98WDJ/p/10712575.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django提供了强大的聚合和分组查询功能,可以对数据库的数据进行统计和分组操作。 聚合查询是指对数据进行集统计查询,常用的聚合函数有求平均值(Avg)、计数(Count)、求最值(Max和Min)以及求和(Sum)。这些聚合函数都定义在django.db.models模块,所以在使用之前需要先导入。 以下是一个使用Django进行聚合查询的示例: ```python from django.db.models import Avg, Count, Max, Min, Sum from myapp.models import MyModel # 求平均值 avg_value = MyModel.objects.aggregate(avg_value=Avg('field_name')) # 计数 count = MyModel.objects.aggregate(count=Count('field_name')) # 求最大值 max_value = MyModel.objects.aggregate(max_value=Max('field_name')) # 求最小值 min_value = MyModel.objects.aggregate(min_value=Min('field_name')) # 求和 sum_value = MyModel.objects.aggregate(sum_value=Sum('field_name')) ``` 分组查询是指将数据按照某个字段进行分组,并对每个分组进行聚合操作。可以使用annotate()方法进行分组查询。 以下是一个使用Django进行分组查询的示例: ```python from django.db.models import Avg, Count, Max, Min, Sum from myapp.models import MyModel # 按照某个字段进行分组,并求每个分组的平均值 result = MyModel.objects.values('field_name').annotate(avg_value=Avg('field_name')) # 按照某个字段进行分组,并求每个分组的计数 result = MyModel.objects.values('field_name').annotate(count=Count('field_name')) # 按照某个字段进行分组,并求每个分组的最大值 result = MyModel.objects.values('field_name').annotate(max_value=Max('field_name')) # 按照某个字段进行分组,并求每个分组的最小值 result = MyModel.objects.values('field_name').annotate(min_value=Min('field_name')) # 按照某个字段进行分组,并求每个分组的求和 result = MyModel.objects.values('field_name').annotate(sum_value=Sum('field_name')) ``` 注意:上述示例的`MyModel`是你自己定义的模型类,需要根据实际情况进行替换。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值