Django的web框架Django Rest_Framework精讲(四)

文章目录

  • 1.DRF认证组件Authentication
  • 2.权限Permissions
  • 3.限流Throttling
  • 4.过滤Filtering
  • 5.排序
  • 6.分页Pagination
  • 7.异常处理 Exceptions
  • 8.自动生成接口文档

大家好,我是景天,今天我们继续DRF的最后一讲,Django的web框架Django Rest_Framework(四)

1.DRF认证组件Authentication

DRF除了提供序列化器,视图组件,路由组件外,还提供了很多其他组件,比如认证组件

创建个auth应用
在这里插入图片描述

DRF默认用的和admin是一套认证系统
查看原码
在这里插入图片描述

可以在配置文件中配置全局默认的认证方案
谁写在前面,优先使用哪个
#session认证,admin后台其实就使用的session认证,其实接口开发很少用到session认证,所以我们通过配置可以改为其他认证,比如后面项目里面我们用到jwt,JSON WEB TOKEN认证,或者一些配合redis的认证
在这里插入图片描述
在这里插入图片描述

我们可以自己写个认证类
auth这个应用名,不能使用,运行程序报错,和系统名称冲突
在这里插入图片描述

自己写认证类,我们可以参照Session认证类原码写法
Session认证类,继承BaseAuthentication,里面就写了两个方法
在这里插入图片描述

再查看BaseAuthentication,里面就写了两个空的方法,啥也没干,说明需要我们继承时重写父类方法
在这里插入图片描述

我们自己定义的认证类

from rest_framework.authentication import BaseAuthentication
from rest_framework.exceptions import AuthenticationFailed

class Auth01(BaseAuthentication):
#在这里写认证逻辑
def authenticate(self, request):
name = 1
if name == 1:
return ‘name’,‘jinghao’ #这里认证返回的元祖数据,第一个被封装在request.user里面,第二个被封装在request.auth里面
else:
#认证失败报错,需要导包
raise AuthenticationFailed(‘认证失败’)

请求来了,先走认证组件,走完认证组件再走视图

全局配置,需要再settings.py里面将我们写的认证组件加进去
在这里插入图片描述

视图类

from rest_framework.views import APIView
from rest_framework.response import Responsefrom ser import modelsclass StudentView(APIView):def get(self,request):print(request.user)print(request.auth)return Response({'msg':'认证成功'})

在这里插入图片描述

浏览器访问
在这里插入图片描述

认证失败:
在这里插入图片描述

返回json字符串字典键是detail 值是我们定义的
在这里插入图片描述

基于登录状态认证,基于requset中的session或cookie的值的判断,来判断用户是否登录

如果认证不通过,视图函数中打印的request.user和request.auth 分别是AnonymousUser和None
在这里插入图片描述

上面是全局的视图函数中都生效,所有访问路径都要认证,如果想让一些路径不认证,还要写白名单,比较麻烦
如果想在个别视图函数中生效,可以定义在视图函数里面

先把全局的注释掉
在这里插入图片描述

在视图函数中,导包,然后使用
#认证组件也可以写成元祖形式的,到时候我们使用我们自己开发的认证组件的时候,写在列表或元祖中来使用

class StudentView(APIView):#局部函数中使用认证authentication_classes = [Auth01,]def get(self,request):print(request.user)print(request.auth)return Response({'msg':'认证成功'})

在这里插入图片描述

认证组件依然生效
在这里插入图片描述

认证失败,返回403状态码
在这里插入图片描述

2.权限Permissions

权限控制可以限制用户对于视图的访问和对于具体数据对象的访问。

  • 在执行视图的dispatch()方法前,会先进行视图访问权限的判断
  • 在通过get_object()获取具体对象时,会进行模型对象访问权限的判断

###使用

可以在配置文件中全局设置默认的权限管理类,如
REST_FRAMEWORK = {

'DEFAULT_PERMISSION_CLASSES': ('rest_framework.permissions.IsAuthenticated', #登录状态下才能访问我们的接口,可以通过退出admin后台之后,你看一下还能不能访问我们正常的接口就看到效果了
)

}

未指明,使用的就是默认的权限配置,允许所有用户访问
在这里插入图片描述

查看原码默认权限:
允许任何人访问
在这里插入图片描述

原码自带的,提供的权限: 自带的基本不用,一般都是自定义

  • AllowAny 允许所有用户
  • IsAuthenticated 仅通过认证的用户
  • IsAdminUser 仅管理员用户
  • IsAuthenticatedOrReadOnly 已经登录的用户可以对数据进行增删改查操作,没登录的用户只能查看
    在这里插入图片描述

自定义权限:
我们写的权限类,继承BasePermission
重写has_permission方法。有权限,返回True, 没有权限返回False
在这里插入图片描述

局部视图函数中使用
在这里插入图片描述

自定义权限类:
比如可以根据 request.user.role == ‘vip’ 判断是vip会员返回True,非vip会员返回False
在这里插入图片描述

全局配置:
在这里插入图片描述

视图函数,没有变化
在这里插入图片描述

认证通过
在这里插入图片描述

如果我们返回Flase
在这里插入图片描述

访问会有报错
在这里插入图片描述

在admin管理系统中,有管理员和非管理员之说,后面我们登录认证不用admin的

局部视图函数使用权限组件
在这里插入图片描述

3.限流Throttling

可以对接口访问的频次进行限制,以减轻服务器压力。

一般用于付费购买次数,投票等场景使用.

##使用,可以全局使用,也可以局部使用

可以在配置文件中,使用DEFAULT_THROTTLE_CLASSES`和 DEFAULT_THROTTLE_RATES进行全局配置,

REST_FRAMEWORK = {'DEFAULT_THROTTLE_CLASSES': ('rest_framework.throttling.AnonRateThrottle', # 匿名用户,未登录的    这俩是DRF提供的访问频率限制类'rest_framework.throttling.UserRateThrottle'  # 经过登录之后的用户),'DEFAULT_THROTTLE_RATES': {'anon': '100/day','user': '1000/day'}
}

在这里插入图片描述

在这里插入图片描述

原码,默认没有做任何访问频率限制
在这里插入图片描述

我们使用DRF自带的:
允许任何用户访问
未登录用户限制每分钟3次,登录用户限制每分钟5次

在这里插入图片描述

超次数之后,就不让访问了
在这里插入图片描述

也可以局部使用
也可以在具体视图中通过throttle_classess属性来配置,如
from rest_framework.throttling import UserRateThrottle
from rest_framework.views import APIView

class ExampleView(APIView):
throttle_classes = (UserRateThrottle,)

自定义访问频率限制:

from rest_framework.throttling import BaseThrottle,SimpleRateThrottle
import time
from rest_framework import exceptions
visit_record = {}
class VisitThrottle(BaseThrottle):# 限制访问时间VISIT_TIME = 10VISIT_COUNT = 3# 定义方法 方法名和参数不能变def allow_request(self, request, view):# 获取登录主机的ipid = request.META.get('REMOTE_ADDR')self.now = time.time()if id not in visit_record:visit_record[id] = []self.history = visit_record[id]# 限制访问时间while self.history and self.now - self.history[-1] > self.VISIT_TIME:self.history.pop()# 此时 history中只保存了最近10秒钟的访问记录if len(self.history) >= self.VISIT_COUNT:return Falseelse:self.history.insert(0, self.now)return Truedef wait(self):     #返回剩余秒数,过多久可以再次访问return self.history[-1] + self.VISIT_TIME - self.now

4.过滤Filtering

对于列表数据可能需要根据字段进行过滤,我们可以通过添加django-fitlter扩展来增强支持。

在这里插入图片描述

需要安装这个模块
pip install django-filter

在这里插入图片描述

和rest_framework一样,需要将该模块注册到应用,settings.py中配置
在这里插入图片描述

rest_framework配置文件中,将过滤器加进去
‘DEFAULT_FILTER_BACKENDS’: (‘django_filters.rest_framework.DjangoFilterBackend’,),

在这里插入图片描述

视图函数中使用过滤字段
filter_fields = (‘name’,‘age’)
在这里插入图片描述

查询时,将过滤参数添加到url中 以 ?name=xx&age=xx 的形式传递过滤参数
用最新的django-filter,过滤一直不生效,一直查询的都是全部数据

在这里插入图片描述

我们换成2.4.0版本就可以了
在这里插入图片描述

可以正常得到过滤数据,版本害死人啊
在这里插入图片描述

多条件组合查询,以&连接
在这里插入图片描述

只能精确查询

5.排序

对于列表数据,REST framework提供了OrderingFilter过滤器来帮助我们快速指明数据按照指定字段进行排序。
使用方法:
在类视图中设置filter_backends,使用rest_framework.filters.OrderingFilter过滤器,REST framework会在请求的查询字符串参数中检查是否包含了ordering参数,如果包含了ordering参数,则按照ordering参数指明的排序字段对数据集进行排序。
前端可以传递的ordering参数的可选字段值需要在ordering_fields中指明。

from rest_framework.filters import OrderingFilter
class Students7View(ModelViewSet):queryset = models.Student.objects.all()  # 必须写这个参数 ,方法中使用的self.get_queryset()方法自动获取到queryset属性数据serializer_class = StudentModelSerializer  # 非必填属性,self.get_serializer获取到serializer_class制定的序列化器类filter_backends = (OrderingFilter,)ordering_fields = ('id', 'age')# students/?ordering=-id# url处写法: 127.0.0.1:8000/books/?ordering=-age 
# 必须是ordering=某个值
# -id 表示针对id字段进行倒序排序
# id  表示针对id字段进行升序排序

在这里插入图片描述

查看已生效
在这里插入图片描述

如果需要在过滤以后再次进行排序,则需要两者结合!

from rest_framework.generics import ListAPIView
from students.models import Student
from .serializers import StudentModelSerializer
from django_filters.rest_framework import DjangoFilterBackend #需要使用一下它才能结合使用
class Student3ListView(ListAPIView):queryset = Student.objects.all()serializer_class = StudentModelSerializerfilter_fields = ('age', 'sex')# 因为filter_backends是局部过滤配置,局部配置会覆盖全局配置,所以需要重新把过滤组件核心类再次声明,# 否则过滤功能会失效filter_backends = [OrderingFilter,DjangoFilterBackend]ordering_fields = ('id', 'age')

#127.0.0.1:8000/books/?sex=1&ordering=-age
在这里插入图片描述

过滤后排序生效
在这里插入图片描述

6.分页Pagination

REST framework提供了分页的支持。

我们可以在配置文件中设置全局的分页方式,如:
REST_FRAMEWORK = {
#全局分页,一旦设置了全局分页,那么我们drf中的视图扩展类里面的list方法提供的列表页都会产生分页的效果。所以一般不用全局分页
‘DEFAULT_PAGINATION_CLASS’: ‘rest_framework.pagination.PageNumberPagination’,
‘PAGE_SIZE’: 100 # 每页最大数据量
}

全局配置:
在这里插入图片描述

每页显示两条,生效
在这里插入图片描述

在这里插入图片描述

而且,上一页下一页链接都做好了,只能说牛逼

在这里插入图片描述

每个页面可能分页每页数量不一样,所以常用局部分页
自定义Pagination类,来为视图添加不同分页行为。在视图中通过pagination_class属性来指明。

class LargeResultsSetPagination(PageNumberPagination):
page_size = 1000
#127.0.0.1:8001/students/?page=5&page_size=10

page_size_query_param = 'page_size'
max_page_size = 10000

class BookDetailView(RetrieveAPIView):
queryset = BookInfo.objects.all()
serializer_class = BookInfoSerializer
pagination_class = LargeResultsSetPagination
# pagination_class = None

from rest_framework.pagination import PageNumberPagination

class LargeResultsSetPagination(PageNumberPagination):
page_size = 3 #每页显示多少条
# 127.0.0.1:8001/students/?page=5&page_size=10

page_size_query_param = 'page_size'  #前端发送的每页数目关键字,前端可以跟聚这个参数来控制每页显示多少条
max_page_size = 10000   #前端最多能设置的每页最大数量,给前端设置个上限,不能无限大

比如,我们代码里写死了每页显示3条,但是前端可以通过url的page_size参数来控制每页显示多少条
在这里插入图片描述

比如在全局里面设置了分页,如果在某个视图里面不想使用分页,添加如下参数
**注意:如果在视图内关闭分页功能,只需在视图内设置
pagination_class = None

可选分页器

1) PageNumberPagination 常用的就是这个

前端访问网址形式:
GET http://127.0.0.1:8000/students/?page=4

可以在子类中定义的属性:

  • page_size 每页数目
  • page_query_param 前端发送的页数关键字名,默认为"page"
  • page_size_query_param 前端发送的每页数目关键字名,默认为None
  • max_page_size 前端最多能设置的每页数量
    在这里插入图片描述

2)LimitOffsetPagination(了解)

前端访问网址形式:#其实就是通过偏移量来取数据

GET http://127.0.0.1/four/students/?limit=100&offset=400 #从下标为400的记录开始,取100条记录

可以在子类中定义的属性:

  • default_limit 默认限制,每页数据量大小,默认值与PAGE_SIZE设置一致
  • limit_query_param limit参数名,默认’limit’ , 可以通过这个参数来改名字
  • offset_query_param offset参数名,默认’offset’ ,可以通过这个参数来改名字
  • max_limit 最大limit限制,默认None, 无限制
    在这里插入图片描述

MySQL的偏移量offset

如果想查询前两条 sql语句后面加上limit 2
select * from ser_student limit 2;
在这里插入图片描述

如果想从第三条开始,查询后面的两条 再加上 offset 2
select * from ser_student limit 2 offset 2; 这句话的意思是从索引为2的记录开始,取2条
之前没有drf的时候,自己写分页就是通过offset偏移量来写

在这里插入图片描述

7.异常处理 Exceptions

我们不可能在所有的视图函数中都做try execpt 操作,这样做麻烦死了,所以我们使用DRF的异常处理类
REST framework提供了异常处理,我们可以自定义异常处理函数。
from rest_framework.views import exception_handler
我们看下原码,就是个函数
在这里插入图片描述

这个函数不能涵盖视图函数所有的错误,出现DRF捕获不到的异常,就返回None。如果程序内部错误没被捕获到,程序就崩了
在这里插入图片描述

因此,我们需要自己创建个异常捕获函数

首先,我们创建个类,模拟抛出异常
在这里插入图片描述

然后自定义异常捕获类

from rest_framework.views import exception_handlerfrom rest_framework.response import Response
from rest_framework import status
from req.views import AA
def myexecption(exc, context):#先执行官方异常捕获函数,官方捕获异常捕获到,就返回错误信息,捕获不到就返回Noneres = exception_handler(exc, context)print('======>',exc, context)#判断如果返回结果为None,有两种情况:1.程序没发生异常。2.程序发生异常了,官方的异常捕获没捕获到if not res:#判断异常类型,如果是AA错误,就返回页面告诉前端是AA错误类型,方便排查if isinstance(exc,AA):return Response({'error':'AA错误'},status=status.HTTP_500_INTERNAL_SERVER_ERROR)else:return None

在配置文件中还要声明自定义的异常处理
REST_FRAMEWORK = {
‘EXCEPTION_HANDLER’: ‘req.utils.except_drf.myexecption’,
}
在这里插入图片描述

如果未声明,会采用默认的方式,如下
REST_FRAMEWORK = {
‘EXCEPTION_HANDLER’: ‘rest_framework.views.exception_handler’
}

请求:
在这里插入图片描述

看下打印的异常信息
exec就是抛出的异常打印信息
context字典里面的 views 指向是哪个视图类 报的错

在这里插入图片描述

做日志的话,可以把错误通过日志记录起来

例如:

补充上处理关于数据库的异常

from rest_framework.views import exception_handler as drf_exception_handler
from rest_framework import status
from django.db import DatabaseErrordef exception_handler(exc, context):response = drf_exception_handler(exc, context)if response is None:view = context['view'] #出错的方法或者函数名称if isinstance(exc, DatabaseError):print('[%s]: %s' % (view, exc))response = Response({'detail': '服务器内部错误'}, status=status.HTTP_507_INSUFFICIENT_STORAGE)return response

REST framework定义的异常

  • APIException 所有异常的父类
  • ParseError 解析错误
  • AuthenticationFailed 认证失败
  • NotAuthenticated 尚未认证
  • PermissionDenied 权限决绝
  • NotFound 未找到
  • MethodNotAllowed 请求方式不支持
  • NotAcceptable 要获取的数据格式不支持
  • Throttled 超过限流次数
  • ValidationError 校验失败

也就是说,上面列出来的异常加粗部分不需要我们自行处理了,很多的没有在上面列出来的异常,就需要我们在自定义异常中自己处理了。
官方原码只帮我们处理了三种报错,其他的需要我们加进去自定义的函数中去

8.自动生成接口文档

写完接口后,一定要对接口功能进行描述,参数是什么,返回值是什么都要说清楚
有的公司以word,excel,或线上html形式来写

比如 聚宽 来测下交易策略行不行
接口文档

在这里插入图片描述

REST framework可以自动帮助我们生成接口文档。就是页面形式生成的接口文档

接口文档以网页的方式呈现。

自动接口文档能生成的是继承自APIView及其子类的视图。

https://www.kernel.org/doc/html/v4.12/core-api/index.html

安装依赖
REST framewrok生成接口文档需要coreapi库的支持。

pip install coreapi

设置接口文档访问路径
在总路由中添加接口文档路径。

文档路由对应的视图配置为rest_framework.documentation.include_docs_urls

参数title为接口文档网站的标题。

from rest_framework.documentation import include_docs_urls

urlpatterns = [

path(‘docs/’, include_docs_urls(title=‘站点页面标题’))
]

总路由里面配置如下:
在这里插入图片描述

如果报下面的错,解决办法
在这里插入图片描述

然后在DRF里面加上如下配置:
REST_FRAMEWORK = {

‘DEFAULT_SCHEMA_CLASS’: “rest_framework.schemas.AutoSchema”,

}

访问接口文档:

在这里插入图片描述

请求方法自动都做好了,参数需要自己写

文档描述说明的定义位置
1) 单一方法的视图,可直接使用类视图的文档字符串,如

class BookListView(generics.ListAPIView):
“”"
get: 返回所有图书信息.
post: 添加记录
“”"
#注意,这是在类中声明的注释,如果在方法中你声明了其他注释,会覆盖这个注释的

在这里插入图片描述
在这里插入图片描述

还可以交互验证接口是否正常

在这里插入图片描述
在这里插入图片描述

2)包含多个方法的视图,在类视图的文档字符串中,分开方法定义,如

class BookListCreateView(generics.ListCreateAPIView):
“”"
get:
返回所有图书信息.

post:
新建图书.
"""

3)对于视图集ViewSet,仍在类视图的文档字符串中封开定义,但是应使用action名称区分,如
“”"
list:
返回图书列表数据

retrieve:
返回图书详情数据latest:
返回最新的图书数据read:
修改图书的阅读量
"""

两点说明:

1) 视图集ViewSet中的retrieve名称,在接口文档网站中叫做read

2)参数的Description需要在模型类或序列化器类的字段中以help_text选项定义,如:
class Student(models.Model):

age = models.IntegerField(default=0, verbose_name=‘年龄’, help_text=‘年龄’)

或注意,如果你多个应用使用同一个序列化器,可能会导致help_text的内容显示有些问题

class StudentSerializer(serializers.ModelSerializer):class Meta:model = Studentfields = "__all__"extra_kwargs = {'age': {'required': True,'help_text': '年龄'}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/666545.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32--揭秘中断(简易土货版)

抢占优先级响应优先级 视频学习--中断​​​​​​​

正则表达式可视化工具regex-vis

什么是正则表达式 ? 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。【百度百科】 正则表达式用简短…

【图论】基环树

基环树其实并不是树,是指有n个点n条边的图,我们知道n个点n-1条边的连通图是树,再加一条边就会形成一个环,所以基环树中一定有一个环,长下面这样: 由基环树可以引申出基环内向树和基环外向树 基环内向树如…

【新书推荐】5.2 位运算符

本节必须掌握的知识点: 位运算 示例十七 代码分析 汇编解析 5.2.1 位运算 位运算符如表5-2所示: 运算符 作用 示例 & 按位与 两个操作数同时为1,结果为1; | 按位或 两个操作数只要有一个为1,结果就为1&a…

【lesson38】让minishell支持重定向

文章目录 minishell支持重定向minishell完整代码 minishell支持重定向 支持重定向的核心逻辑: 1.分析字符串是否含有重定向的符号,并且提取文件名。 #define INPUT_REDIR 0 //输入重定向 #define OUTPUT_REDIR 1 //输出重定向 #define APPEND_REDIR…

电脑上常见的绘图软件有哪些?

现在在电脑上绘图很流行,不仅可以随时更改,还可以提高绘图效率,绘图软件中有很多工具。市场上的计算机绘图软件种类繁多。包括艺术设计、工业绘图和3D绘图。那么每个绘图软件都有自己的特点。那么,哪个更适合计算机绘画软件呢&…

路由器、路由器的构成、交换结构

目录 1 路由器 1.1 路由器的结构 “转发”和“路由选择”的区别 1.1.1 输入端口对线路上收到的分组的处理 1.1.2 输出端口将交换结构传送来的分组发送到线路 2.2 交换结构 2.2.1 通过存储器 2.2.2 通过总线 2.2.3 通过纵横交换结构 (crossbar switch fabric) 1 路由器…

算法练习-环形链表(思路+流程图+代码)

难度参考 难度:中等 分类:链表 难度与分类由我所参与的培训课程提供,但需要注意的是,难度与分类仅供参考。且所在课程未提供测试平台,故实现代码主要为自行测试的那种,以下内容均为个人笔记,旨在…

用Jmeter进行接口测试

web接口测试工具: 手工测试的话可以用postman ,自动化测试多是用到 Jmeter(开源)、soupUI(开源&商业版)。 下面将对前一篇Postman做接口测试中的接口用Jmeter来实现。 一、Jmeter 的使用步骤 打开Jme…

SpringCloud Gateway(4.1.0) 返回503:原因分析与解决方案

文章目录 一、环境版本二、原因分析三、解决方案 一、环境版本 Versionspring-cloud-dependencies2023.0.0spring-cloud-starter-gateway4.1.0Nacosv2.3.0 二、原因分析 在 Spring Cloud Gateway 的早期版本中,Ribbon 被用作默认的负载均衡器。随着Spring Cloud的…

修复wordpress安全漏洞

1. 问题描述: 用wordpress建了一个网站,但是学校反映说存在安全漏洞,通过接口https://xxx.xxx.edu.cn/?rest_route/wp/v2/users/可以访问到一些内容,希望可以关闭这个接口。 2. 解决办法 一共两步 (1)在fu…

系统架构20 - 统一建模语言UML(上)

统一建模语言 组成要素事物关系 在目前的软件开发方法中,面向对象的方法占据着主导地位。面向对象方法的主导地位也决定着软件开发过程模型化技术的发展,面向对象的建模技术方法也就成为主导的方法。 公认的面向对象建模语言出现于20世纪70年代中期。从1…

vulhub中Adminer ElasticSearch 和 ClickHouse 错误页面SSRF漏洞复现(CVE-2021-21311)

Adminer是一个PHP编写的开源数据库管理工具,支持MySQL、MariaDB、PostgreSQL、SQLite、MS SQL、Oracle、Elasticsearch、MongoDB等数据库。 在其4.0.0到4.7.9版本之间,连接 ElasticSearch 和 ClickHouse 数据库时存在一处服务端请求伪造漏洞&#xff08…

学习ArtTs -- 初见ArkTs

作者:Uncle_Tom 原文链接:学习ArtTs -- 初见ArkTs-云社区-华为云 1. 前言 需要静态分析去检查一个语言,必须对这个语言有深刻的认识,才能有效的对这个语言进行有效的检查。 我常说:“作为一个程序分析员需要比一般的程序员考虑…

反演LAI(二)基于查找表的反演

反演LAI(二)基于查找表的反演 相关波段选取 首先我们使用gf-1数据有四个波段,使用其他高光谱会有几十个波段,但并不是所有波段都需要选用,lai对于不同波段的响应不同。根据上一节的敏感性分析结果,可以发现,400-500,600-700的两个波段对于LAI敏感性更大,因此选取这两…

【人工智能时代】AI赋能编程 | 自动化工具助力高效办公

前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家:https://www.captainbed.cn/z ChatGPT体验地址 文章目录 前言泡泡AI工具卡片思维导图Markdown编辑器 其他工具文件免费处理工具结语 合集…

【C/C++ 11】贪吃蛇游戏

一、题目 贪吃蛇游戏机制是通过控制蛇上下左右移动并吃到食物得分。 蛇头碰到墙壁或者碰到蛇身就游戏结束。 食物随机生成,蛇吃到食物之后蛇身变长,蛇速加快。 二、算法 1. 初始化游戏地图并打印,地图的边缘是墙,地图的每个坐…

Python tkinter (14) —— 按键事件

本文主要介绍Python tkinter 几种按键事件及其示例。 目录 按键事件 响应所有按键事件 窗体绑定事件 响应特殊按键事件 指定按键事件 组合按键事件 总结 tkinter系列文章 python tkinter窗口简单实现 Python tkinter (1) —— Label标签 Python tkinter (2) —— But…

Kafka相关内容复习

为什么要用消息队列 解耦 允许你独立的扩展或修改两边的处理过程,只要确保它们遵守同样的接口约束。 可恢复性 系统的一部分组件失效时,不会影响到整个系统。消息队列降低了进程间的耦合度,所以即使一个处理消息的进程挂掉,加入队…

Transformer 自然语言处理(三)

原文:Natural Language Processing with Transformers 译者:飞龙 协议:CC BY-NC-SA 4.0 第八章:使 transformers 在生产中更高效 在之前的章节中,您已经看到了 transformers 如何被微调以在各种任务上产生出色的结果。…