Django入门

1.环境安装

django支持python3+,且只支持python2.7

1)安装python

https://www.python.org/downloads/release/python-2715/
image.png

2)安装django

www.djangoproject.com
image.png

django 对python的支持情况
安装1.10.2版本django

pip install Django==1.10.2

image.png

判断django是否安装成功:

python -m django --version

2.创建django

安装完django后命令行中就多了行django命令,选择好安装目录

django-amdin startproject myblog (项目名称:myblog 定义好名称后运用时不建议修改,配置文件中也是以myblog命名配置)
image.png

项目结构:
image.png

1.manage.py
与项目进行交互的命令行工具集的入口(项目管理器)
启动命令:
python manage.py runserver
python manage.py runserver + 端口号
默认端口 8000
image.png

2.wsgi.py(基本不用修改)
WSGI(Python Web Server Gateway Interface)
python服务器网关接口
python应用与web服务器之间的接口

3.urls.py
配置url

4.settings.py
项目的总配置文件
里面包含数据库、web应用、时间等各种配置
1.BASE_DIR :项目根目录
2.SECRET_KEY:项目安全码
3.DEBUG:不要在实际生产中打开
4.ALLOWED_HOSTS:只允许外部访问地址
5.INSTALLED_APPS:django应用
6.MIDDLEWARE:中间件
7.ROOT_URLCONF:url根路径
8.TEMPLATES:模板文件
9.DATABASES:数据库配置,默认是sqlite,如要自定义数据库到 https://docs.djangoproject.com/en/1.10/ref/settings/#databases 中寻找配置方式
10.AUTH_PASSWORD_VALIDATORS:密码认证
11.STATIC_URL:静态文件

5._init_.py
声明模块文件,一般为空

3.创建应用

 1.打开命令行,进入项目中manage.py同级目录
 
 2. 输入命令:python manage.py startapp blog

image.png

 3. 添加应用名到settings.py 中的INSTALLED_APPS中

image.png

4.应用目录介绍

 1.migrations
    数据移植(迁移) 模块
 2.admin.py
    该应用的后台管理系统配置
 3.apps.py
    该应用 的配置
    1.8+后自动生成
 4.models.py
    数据模块,使用ORM框架,类似MVC的模型
 5.test.py
    自动化测试模块 
 6.views.py
    执行响应代码所在模块
    代码逻辑处理的主要地点
    项目大部分代码在这编写

5.创建第一个响应

代码:

from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.

def index(request):
    return HttpResponse("Hello,world!")

配置url:myblog>urls.py
image.png
查看结果:
image.png

6.配置url

1)在blog目录下创建urls.py

image.png

from django.conf.urls import url

from . import views
urlpatterns = [
    url(r'^index/', views.index),
]

2)在urls.py中引用blog.urls

image.png

7.Template

1.

Django使用了一种特殊的模板语言(Django Template Language,DTL)
可以使用第三方模板Jinja2
image.png
image.png

1)在APP的根目录下创建Templates的目录
2)在该目录下创建HTML文件
3)在views.py中返回render
from django.shortcuts import render
from django.http import HttpResponse

#render包含三个参数,第一个是request请求,第二个是返回页面地址(即html),第三个为返回数据
def index(request):
    return render(request, 'index.html')

2.DTL初步使用
render()函数中支持一个dict类型参数(键值对)
该字典是后台参数传递到模板的参数,键为参数名
在模板中使用{{参数名}}来直接使用

views.py:

from django.shortcuts import render
from django.http import HttpResponse

def index(request):
    return render(request, 'index.html', {'hello': 'Hello,Blog!'})

index.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>{{hello}}</h1>
</body>
</html>

image.png

***Django第一个坑

Django查找Template
Django按照INSTALLED_APP中的添加顺序查找Templates
不同APP下Templates目录中的同名.html文件会造成冲突
####解决方案
在APP的Templates目录下创建以APP名为名称的目录
将html文件放入新创建的目录下
image.png

8.Models

ORM(对象关系映射)
实现了对象与数据之间的映射
隐藏了数据访问的细节,不需要编写sql语句

    通常,一个Model对应数据库的一张数据表
    Django中Models以类的形式表现
    它包含了一些基本字段以及数据的一些行为
1)在应用根目录下创建models.py,并引入models模块(Django已完成)
2)创建类,继承models.Model,该类即是一张数据表
3)在类中创建字段
   字段即类里面的属性(变量)
   attr=models.CharField(max_length=64)

models.py:

from __future__ import unicode_literals

from django.db import models

class Article(models.Model):
    title = models.CharField(max_length=32, default='Title')
    content = models.TextField(nul=True)
4)生成数据表
1.命令行中进入manage.py同级目录
2.执行python manage.py makemigrations app名(可选)
3.再执行python manage.py migrate
4.Django在app/migrations/目录下生成移植文件
5.执行python manage.py sqlmigrate 应用名 文件id 查看SQL语句
6.默认sqlite3的数据库在项目根目录下db.sqlite3
5)页面数据呈现
1.views.py中import models
2.article = models.Article.objects.get(pk=1)
3. render(request,page,{‘article’ : article})

views.py:

from django.shortcuts import render
from django.http import HttpResponse
from . import models

def index(request):
    article = models.Article.objects.get(pk=1)
    return render(request, 'blog/index.html', {'article': article})

index.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>{{article.id}}</h1>
    <h1>{{article.title}}</h1>
    <h1>{{article.content}}</h1>
</body>
</html>

image.png

9.Admin

Admin是Django自带的一个功能强大的自动化数据管理页面
被授权的用户可直接在Admin中管理数据库
Django提供了许多针对Admin的定制功能

1)配置Admin
1.创建用户
  python manage.py createsuperuser  创建超级用户
2.localhost:8000/admin/ Admin 入口
3.修改settings.py 中 LANGUAGE_CODE=‘zh_Hans’ 英文变中文操作界面
2)配置应用
1.在应用下admin.py中引入自身的models模块(或里面的模型类)
2.编辑admin.py: admin.site.register(models.Article)

admin.py:

from django.contrib import admin

from models import Article

admin.site.register(Article)

3)当前显示很不方便,需要修改数据默认显示名称
image.png

    在Article类下添加一个方法
    根据Python版本选择_str_(self)  【3.0+】 或 _unicode_(self) 【2.7+】
    return self.title

models.py:

from __future__ import unicode_literals

from django.db import models

class Article(models.Model):
    title = models.CharField(max_length=32, default='Title')
    content = models.TextField(null=True)

    def __unicode__(self):
        return  self.title

image.png

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值