django-admin startproject djweb 生成djweb项目
django-admin startapp news 生成news应用
配置models文件
class NewInfo(models.Model):
title = models.CharField(max_length=30)
content = models.TextField()
b_date= models.DateField()
read = models.IntegerField()
插入数据,进入交互环境: python manage.py shell
In [1]: from news.models import NewInfo
In [2]: NewInfo.objects.all()
Out[2]: <QuerySet []>
# 查询为空,这时插入数据
In [11]: n1= NewInfo()
In [12]: n1.title = 'title1'
In [13]: n1.read = 999
In [14]: n1.b_date= '2024-01-01'
In [15]: n1.save()
In [20]: res = NewInfo.objects.all()[0]
In [21]: res.title # 保存成功
Out[21]: 'title1'
配置admin文件
from .models import NewInfo
# Register your models here.
admin.site.register(NewInfo)
创建超级用户:python manage.py createsuperuser
用户名 (leave blank to use 'pass'): pass
电子邮件地址: xxx@qq.com
Password:
Password (again):
密码跟 用户名 太相似了。
密码长度太短。密码必须包含至少 8 个字符。
这个密码太常见了。
Bypass password validation and create user anyway? [y/N]: y
Superuser created successfully.
启动项目:python manage.py runserver
登录web页面:http://127.0.0.1:8000/admin
点击增加信息:
展示中文信息及调整时区:
# LANGUAGE_CODE = 'en-us'
LANGUAGE_CODE = 'zh-hans'
# TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/Shanghai'
点击删除信息:
自定义admin模型类展示数据
class NewInfoAdmin(admin.ModelAdmin):
# 自定义模型类
list_display = ['id','title','b_date','read']
# 自定义模型定义到系统中
admin.site.register(NewInfo,NewInfoAdmin)
展示结果:
总路由分配:
from django.contrib import admin
from django.urls import path,re_path,include
urlpatterns = [
path('admin/', admin.site.urls),
re_path(r'^news/',include('news.urls'))
]
子路由配置:
from .views import home
urlpatterns = [
path('home/',home),
]
debug模式调试代码:
关闭原有terminal进程,点击debug模式,选择红色按钮断点,此时刷新web页面的访问url地址.
templates模板配置:
# 项目目录位置的模板
# 'DIRS': [],
'DIRS': [BASE_DIR / 'templates'],
msyql数据库配置:
mysql> create database djweb charset = utf8;
Query OK, 1 row affected, 1 warning (0.00 sec)
mysql> exit
Bye
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'djweb',
'USER':'root',
'PASSWORD':'****',
'HOST':'localhost',
'PORT':3306
}
}
ORM常用字段类型:
- AutoField
- BooleanField
- CharField
- TextField
- DecimalField
- TimeField
- DateTimeField
- FileField
常用字段选项:
- default
- primary_key
- unique
- db_index # 索引
- null
- blank
- verbose_name # web可读
- help_text
关系字段类型:
ForeignKey :一对多,将字段定义在多的一方中
goods = models.ForeginKey('Goods',on_delete=models.CASCADE)
ManyToManyField: 多对多
users = models.ManToManyField('Users',on_delete=models.CASCADE)
OneToOneField:一对一
goods = models.OneToOneField('Goods',on_delete=models.CASCADE)
自定义关联:使用self指定
goods = models.ForeginKey('self',null=True,blank = True)
goods = models.ManyToManyField('self',null=True,blank = True)
多对对模型类实践案例:
class NewInfo(models.Model):
title = models.CharField(max_length=30,verbose_name='标题',help_text="标题")
content = models.TextField(max_length=30,verbose_name="内容",help_text='内容')
# b_date= models.DateField()
read = models.IntegerField(verbose_name='阅读量',help_text='评论数量')
type = models.ManyToManyField('NewsType',verbose_name='新闻类型',help_text='类型')
class NewsType(models.Model):
name = models.CharField(max_length=20,verbose_name='名称')
元选项:
class Meta:
# 自定义表名,若无此设置默认为表名:应用名+模型类小写
db_table = 'news'
verbose_name = '新闻类型' # 后台可以看到
结果实例:
魔术方法__str__应用
def __str__(self): # 魔术方法 -- 更改对象显示的内容
return self.name
模糊条件查询:
- xxx.objects.filter(模型类名__条件名 = 值)
- xxx.objects.filter(name__contains='xxx')
- xxx.objects.filter(name__startswith='xxx')
- xxx.objects.filter(name__endswith='xxx')
- xxx.objects.filter(name__in=[1,2,3])
比较条件查询:
- xxx.objects.filter(id__gt=1) # 大于
- xxx.objects.filter(id__lt=1) # 小于
- xxx.objects.filter(id__gte=1) # 大于等于
- xxx.objects.filter(id__lte=1) # 小于等于
F对象与Q对象(from django.db.models import F)
- F对象用于类属性比较 eg: xxx.objects.filter(read__gte=F('comment'))
- Q对象用于逻辑与或非(&|~) eg: xxx.objects.filter(Q(read__gte=40) & Q(comment__gt=30))
聚合函数(from django.db.models import Sum,Avg,Max,Min)
eg: xxx.objects.all().aggregate(Sum('read'))
- Sum
- Count
- Avg
- Max
- Min
查询和对象关联的数据
一到多查询:
data = xxx.objects.get(id=1)
data.newinfo_set.all() # 模型类名小写+_set实现
多到一查询:
data = xxx.object.get(id=1)
data.title # 通过关联的对象直接获取对应的数据
由一模型类查询多模型类数据
语法: 关联模型类名小写__属性名__条件运算符=值
data=xxx.objects.filter(类名小写__属性名__contains='q') # 查询某一属性包含q的字段
由多模型类查询一模型类数据
语法: 一模型类名小写__一模型类属性名__条件运算符=值
data=xxx.objects.filter(类名小写__属性名='yyy') # 查询属性包含yyy的所有字段
ORM增删改查操作:
- 修改数据: 查到要修改的对象,直接修改字段xxx.title='yyy',save()方法保存
- 增加数据: xxx.属性值=特定值, xxx.save()保存
- 删除数据: 获取data = xxx.objects.all(),然后xxx.delete()直接删除
路由参数匹配
-
位置参数:
re_path(r'^index/(\d+)/$',views.show) # 直接使用小括号
-
关键字参数:
re_path(r'^index/(?P<name1>\d+)/$',views.show)
requests对象的属性
- path
- method
- encoding
- GET # ?'key1'='value1'&'key2'='value2'
- POST
- FILES
- COOKIES
- session
HttpResponse对象
- content
- charset
- status_code
- content-type
常用方法
set_cookie(key,value='',max_age=None,expires=None)
# max_age 整数,指定过期时间
# expires 指定日期的特定过期时间
# 上面二选一,若无指定关闭浏览器时cookies会过期
eg:
response = HttpResponse(res_list,status)
response.set_cookie('token','xxx',max_age=4)
response.delete_cookie('token')
session的操作
- request.session['key']='value'
- request.session.get('key',None)
- request.session.clear() # 清除所有session数据
- request.session.flush() # 清除存储中的整条数据
- del request.session['key']
- request.session.set_expiry(value) # 设置会话的超时时间
类视图的使用步骤:
# views.py
from django.views import View
class NewsView(View):
def get(self,request):
pass
def post(self,request):
pass
# urls.py
re.path(r'news/$',views.NewView.as_view())
模板变量
语法:{{ 变量 }}
顺序解析dict.title:
- 字典dict['title'] 先属性后方法,若无此属性,再查询对应方法
- 若格式dict.0则解析为列表dict[0],若变量不存在则为空字符串
模板标签
语法:{% xxx %}
for标签
{% for x in xxx %}
{{forloop.counter} # 表示当前第几次循环,从1开始
{% empty %} # 列表为空或不存在时执行该逻辑
{% endfor %}
if标签
{% if ... %}
{% elif ... %}
{% else %}
{% endif %}
过滤器
语法:{{ 管道符号 | 过滤器 }} eg:{{ xxx | lower}}
- {{ xxx | upper }}
- {{ xxx | lower }}
- {{ xxx | add:2 }}
- {{ datex | date:'y-m-d' }}
注释
语法: {# xxx #}
父模板
{% block xxx %}
{% endblock xxx %}
子模板
{{% extends '父路径path'%}}
{% block xxx %}
{% endblock xxx %}
中间件
# 初始化
def __init__(self):
pass
# 处理请求前
def process_request(self,request):
pass
# 处理视图前
def process_view(self,request,func,*args,**kwargs):
pass
# 处理视图后
def process_response(self,request,response):
pass
# 处理异常
def process_exception(self,request,exception):
pass
自带认证方式登录
from django.contrib.auth import authenticate
username = request.POST['name']
password = request.POST['passwd']
user = authenticate(request,username=username,password=password)
if not user:
pass