Django(复习篇)

项目创建
1. 虚拟环境
python -m venv my_env
​
cd my_env
activate/deactivate
​
pip install django
​

2. 项目和app创建
cd mypros
django-admin startproject Pro1
django-admin startapp app1
​

3. settings配置
    INSTALLED_APPS【app1"】
    TEMPLATES【 'DIRS': [os.path.join(BASE_DIR,"templates")]】
    LANGUAGE_CODE = 'zh-hans'
    TIME_ZONE = 'Asia/Shanghai'
MVT Demo
urls --> app.views --> templates/test.html
​
### urls.py 
from app1.views import test1
urlpatterns = [
    ...,
    path("/test1",test1)
]
​

### app1.views.py
def test1(request):
    return render(request,"app1/test1.html",context={"msg":"hello world"})
​

### templates/test1.html
# TEMPLATES【 'DIRS': [os.path.join(BASE_DIR,"templates")]】
# "app1/test1.html"
new >> Pro1/templates
new >> Pro1/templates/app1/test1.html
{{ msg  }}

ORM
### install mysql dependency
pip install mysqlclient 【recommend】
pip install pymysql【
    app/__init__.py:
    import pymysql
    pymysql.install_as_MySQLdb()
】
​

### settings.py
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        "NAME":"test1",
        "HOST":"localhost"
        "PORT":3306,
        "USER":"root",
        "PASSWORD":"root",
    }
}
​

### mysql
mysql -uroot -proot
show databases;
create database test1;
​

### orm
class Users(models.Model):
    # id 自动生成
    name = models.CharField(max_length=255,verbose_name="用户名")
    age = models.IntegerField(verbose_name="用户年龄")

class Account(models.Model):
    KIND_CHOICE = (
        (1,"普通用户"),
        (2,"VIP用户"),
    )
    # id 自动生成
    balance = models.DecimalField(max_digits=10,decimal_places=2,verbose_name="账户余额")
    kind = models.IntegerField(choices=KIND_CHOICE,verbose_name="账户类型")
    user = models.ForeignKey(to="app1.Users",verbose_name="账户用户名",on_delete=models.CASCADE)
​

### migrate
python manage.py makemigrations
python manage.py migrate

Admin Manger
### simple register model(admin.py)
from django.contrib import admin
from .models import Users,Account
admin.site.register(Users)
admin.site.register(Account)
​

### create super user: admin manage-user(Terminal)
python manage.py createsuperuser


### admin page show:verbose_name(models.py)
class Users(models.Model):
    class Meta:
        verbose_name = verbose_name_plural = "用户"
    pass
    
class Account(models.Model):
    class Meta:
        verbose_name = verbose_name_plural = "用户账户"
    pass
 
### admin page show: list_display(admin.py)
# @admin.register(Users)
class UsersAdmin(admin.ModelAdmin):
    list_display = ("id","name","age")
​
@admin.register(Account)
class AccountAdmin(admin.ModelAdmin):
    list_display = ("id","user","balance","kind")
    
# admin.site.register(Users)
# admin.site.register(Account)
admin.site.register(Users,UsersAdmin)

### admin page show: app verbose name(apps.py)
class App1Config(AppConfig):
    verbose_name = "我的应用1"
    pass

 

### admin page show:model object str name
class Users(models.Model):
    def __str__(self):
        return "%s"%(self.name)
    pass
​
class Account(models.Model):
    def __str__(self):
        return "%s账户"%(self.user.name)
    pass

### admin page show:records ordering(admin.py)
class UsersAdmin(admin.ModelAdmin):
    ordering = ["id"]   # ordering = ["-id"]
    pass

### admin page show:fieldsets of add form(admin.py)
class AccountAdmin(admin.ModelAdmin):
    fieldsets = (
        ("账户信息", {
            "description":"请输入用户信息",
            "fields":("kind","balance")
        }),
        ("所有者",{
            "description": "请输入用户所有者",
            "fields":("user",)
        })
    )

 

### admin page show:search fields(admin.py)
search_fields = ["name"]
 
### admin page show:Tabular inline Edit(admin.py)
class AccountInline(admin.TabularInline):
    extra = 1
    model = Account
​
class UsersAdmin(admin.ModelAdmin):
    inlines = [AccountInline,]
 
### admin page show:custom css style (admin.py)
# settings.py
STATIC_URL = '/static/'
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
​
# admin.py
class UsersAdmin(admin.ModelAdmin):
    class Media:
        css = {
            "all": ("/static/css/admin/admin_user.css",),
        }
    pass

Template
{{ msg }}
{{ user.name }}
​
{% csrf_token %}
​
{% for user in users %}
    {% if user.age > 18 %}
        <p>adult</p>
    {% else %}
        <p>minor</p>
    {% endif %}
{% end for %}
​
{% for key,value in dict.items %}
    <p>{{ key }}:{{ value }}</p>
{% endfor %}
​
{{ data | default:"<p style='color:red'>还没有任何数据哦</p>" }}
{{ content | slice:":20" }}
{{ getDate | date:"Y/m/d" }}

{% extends "base.html" %}

{% block main %}
{% endblock %}
URL
### re_path:query_param、named-group
from django.urls import path,re_path
urlpatterns = [
    path("index",test,name="index"),
    re_path(r"^app1/(?P<page>[1-9]+)$",test1),
]
def test(request):
    # localhost:8000/index?name=joden&age=20
    print(request.GET.dict)
    print(request.GET.get("name"))
    
def test1(request,page):
    # re_path page group => param: page  
    print("page:",page)
    print(request.GET.dict())
​
​
    
### url name
re_path(r'app1/(?P<page>[1-9]+)$', test1, name="index"),
​
def test(request):
    print(reverse("index",kwargs={"page":2}))
​
    
### url namespace
from django.urls import include
path("app1",include("app1.urls"))
# app1/urls.py
app_name = "app1" 
re_path(r'page/(?P<page>[1-9]+)$', test1, name="index"),
# views.py
reverse("app1:index",kwargs={"page":2}) 
CBV
CBV:Class Basic View
https://docs.djangoproject.com/zh-hans/4.1/ref/class-based-views/
    
### View
from django.view import View
class TestView(View):
    def get(self,request,*args,**kwargs):
        return render(request,"app1/test1.html")
    def post(self,request,*args,**kwargs):
        pass
    
urlpatterns = [
    path("app",TestView.as_view()),
]
    
    
### TemplateView
from django.views.generic.base import TemplateView
class TestTemplateView(TemplateView):
    tempate_name = "app1/test1.html"
    def get_context_data(self,**kwargs):
        super().get_context_data(self,**kwargs)
        context = {
            "users":Users.objects.all(),
        }
        return context
​
​
### ListView
from django.views.generic.list import ListView
class TestListView(ListView):
    template_name = "app1/test1.html"
    model = User
    paginate_by = 2     # 3 user/per page
    def get_context_data(self,**kwargs):
        context = super().get_context_data(self,**kwargs)
        print(self.get_paginator(self.object_list,self.paginate_by).num_pages)
        return context
    
{% for user in object_list %}
{% endfor %}

Cookie and Session
### cookie
class TestListView(ListView):
    def get(self,request,*args,**kwargs):
        # get cookie(request)
        request.get_cookie("name")
        response = super(TestListView, self).get(*args,**kwargs)
        # set cookie(response)
        response.set_cookie("name","joden")
        return response
​
    
    
### session
class TestListView(ListView):
    def get(self,request,*args,**kwargs):
        # get session
        get_session_name = request.session.get("sname","")
        # set session
        request.session["sname"] = "value"
        return super(TestListView, self).get(*args,**kwargs)

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值