1、安装,指定安装2.2版本
data:image/s3,"s3://crabby-images/ab8a8/ab8a87d2caf418a7c376e1274de7e7fa90933d5a" alt=""
pip install django==2.2 -i http://pypi.douban.com/simple --trusted-host pypi.douban.com
2、创建测试项目
django-admin.py startproject testDjango
cd testDjango
python manage.py runserver
生成目录结构如下
data:image/s3,"s3://crabby-images/b9965/b9965c813d4a3fcf36590d79239cb1d946a62772" alt=""
目录结构说明:
testDjango: 项目的容器。
manage.py: 一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互。
testDjango/init.py: 一个空文件,告诉 Python 该目录是一个 Python 包。
testDjango/settings.py: 该 Django 项目的设置/配置。
testDjango/urls.py: 该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录"。
testDjango/wsgi.py: 一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目。
访问地址为http://127.0.0.1:8000
data:image/s3,"s3://crabby-images/e65c2/e65c2580033181c3dfbc93ade8eac7eb6b8efbf9" alt=""
修改默认视图,在testDjango项目下创建一个Index.py文件,并输出This is my first django project,这里我们需要使用django的http模块的httpresponse函数坐输出渲染
Index.py文件
from django.http import HttpResponse
def index(request):
return HttpResponse("This is my first django project")
urls.py文件
from django.urls import path
from . import Index
urlpatterns = [
path('', Index.index),
]
访问效果如图
data:image/s3,"s3://crabby-images/17331/1733138c97c2e92e1a2618d3a8c0828156f7ad74" alt=""
urls或者添加path
from django.urls import path
from . import Index
urlpatterns = [
path('index/', Index.index),
]
访问的时候加index路径
data:image/s3,"s3://crabby-images/4b35d/4b35d171ecafbfd8bed2057d060b45b600df7cee" alt=""
3、django可以包含多个模块,创建后台管理模块
python manage.py startapp sysadmin
执行上面的命令会在当前路径下创建admin目录,其目录结构如下所示:
init.py:一个空文件,告诉Python解释器这个目录应该被视为一个Python的包。
admin.py:可以用来注册模型,用于在Django的管理界面管理模型。
apps.py:当前应用的配置文件。
migrations:存放与模型有关的数据库迁移信息。
init.py:一个空文件,告诉Python解释器这个目录应该被视为一个Python的包。
models.py:存放应用的数据模型,即实体类及其之间的关系(MVC/MTV中的M)。
tests.py:包含测试应用各项功能的测试类和测试函数。
views.py:处理请求并返回响应的函数(MVC中的C,MTV中的V)。
sysadmin模块下创建views.py视图
from django.http import HttpResponse
def view(res):
return HttpResponse("<h1> At such a time of crisis,we must try to set aside all differences and stick together")
在新模块下创建url映射匹配规则,urls.py,path不填表示默认访问路径为根路径
from django.urls import path
from . import views
urlpatterns = [
path('', views.view)
]
4、接下来对新模块的url在项目中进行合并,在项目下urls.py使用include进行合并,sysadmin代表模块
from django.urls import path, include
from . import views
urlpatterns = [
path('', views.view),
path('sysadmin/',include('sysadmin.urls') )
]
data:image/s3,"s3://crabby-images/42bbf/42bbf18ca945bce7efd120495cfd8f730460eace" alt=""
访问效果如下图
data:image/s3,"s3://crabby-images/f84a0/f84a0a826f51f49fa743ede1e3e2ab2e3c87ebe3" alt=""
4、使用django模板显示
在sysadmin模块下创建list视图view.py
from django.shortcuts import render
dict_words = [
{'word': 'diversity', 'meaning': 'the diversity of something is the fact that it contains many very different elements', 'eg': 'the cultural diversity of british society'},
{'word': 'antique', 'meaning': 'something made in an earlier period that is collected and considered to have value because it is beautiful, rare, old, or high quality', 'eg': 'My mother collects antique'},
{'word': 'stuff', 'meaning': 'You can use stuff to refer to things such as a substance, a collection of things, events, or ideas', 'eg': ' do not tell me you still believe in all that stuff'},
]
def sysadmin(res):
return render(res, 'word.html', {'dict_words': dict_words})
在模块创建跳转入口,urls.py
from django.urls import path
from . import views
urlpatterns = [
path('', views.sysadmin)
]
在项目下创建templates模板目录
data:image/s3,"s3://crabby-images/1351e/1351e54f6e1441745c342d9eca81efaafe585dc1" alt=""
<h1>This is word page</h1>
<table>
<tr>
<th>word</th>
<th>meaning</th>
<th>eg</th>
</tr>
{% for word in dict_words%}
<tr>
<td>{{word.word}}</td>
<td>{{word.meaning}}</td>
<td>{{word.eg}}</td>
</tr>
{% endfor %}
</table>
在项目下urls.py合并url
from django.urls import path, include
from . import view
urlpatterns = [
path('', view.index),
path('sysadmin/', include('sysadmin.urls'))
]
最后修改项目的默认模板设置,将创建的templates目录添加到里面来
data:image/s3,"s3://crabby-images/c2c25/c2c250e728d6f68860957eb2aba377815b0d57ae" alt=""
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
最后启动效果如果
data:image/s3,"s3://crabby-images/6172e/6172e724e7a27fac097b87ad26772ae56b5e95bb" alt=""
6、数据库操作
安装数据库模块
pip install -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com pymysql
在项目下init文件加入初始化数据库代码
import pymysql
pymysql.install_as_MySQLdb()
在setting文件配置数据库
data:image/s3,"s3://crabby-images/3f9cf/3f9cfc6a596710961acd5715802b3ec76692ef97" alt=""
创建数据库
create database lw_word default charset utf8;
新建模块并注册到app
data:image/s3,"s3://crabby-images/80aaf/80aafd057380e2813eceff08296f8e5f0fba9f7f" alt=""
pip卸载软件
pip uninstall name
在models文件定义model模型,
from django.db import models
class Article(models.Model):
article_id = models.AutoField(primary_key=True)
title = models.TextField()
brief_content = models.TextField()
content = models.TextField()
publish = models.DateTimeField(auto_now=True)
生成迁移文件
python manage.py makemigrations
同步到数据库
python manage.py migrate
数据库建表完成
data:image/s3,"s3://crabby-images/6cb85/6cb85f63f70192c32fcc3f0647c652a3c3fe3f8a" alt=""
7、使用django shell 插入数据
python manage.py shell 进入django shell
data:image/s3,"s3://crabby-images/e8744/e8744b9cefd958cbecaa014d3331c88b188f57ed" alt=""
from blog.models import Article
article = Article()
article.title = 'blog'
article.brief_content = 'provide sb for sth'
article.content = 'provide sb for sth'
article.save()
获取数据库的数据
articles = Article.objects.all()
article = articles[0]
article = articles[2]
print(article.content)
说明数据插入成功
provide sb for sth
8、django admin 模块
data:image/s3,"s3://crabby-images/b1846/b18461de50f7ac1a8d6804863a9f7e29376f7b72" alt=""
data:image/s3,"s3://crabby-images/1ef59/1ef59e785cfeb982f9c654b787a2d76a752191fc" alt=""
data:image/s3,"s3://crabby-images/a4d29/a4d2989670777b5cb290e03ace16f528e3adb36f" alt=""
创建超级管理员账号。
source-shell
(venv)$ python manage.py createsuperuser
Username (leave blank to use 'tk'):tk
Email address: tk@qq.com
Password:
Password (again):
Superuser created successfully.
启动Web服务器,登录后台管理系统。
source-shell
(venv)$ python manage.py runserver
访问[http://127.0.0.1:8000/admin](http://127.0.0.1:8000/admin),会来到如下图所示的登录界面。
data:image/s3,"s3://crabby-images/0a70c/0a70cf963b53d9052b3ae711dd9b3cac2e8e93ba" alt=""
登录后进入管理员操作平台。
data:image/s3,"s3://crabby-images/8bff1/8bff1fb0b3d2bdaf0c091fc1cf5ad7833042437c" alt=""
至此我们还没有看到之前创建的模型类,需要在应用的admin.py文件中模型进行注册。
注册模型类。
(venv)$ vim blog/admin.py
from django.contrib import admin
from .models import Article
admin.site.register(Article)
注册模型类后,就可以在后台管理系统中看到它们。
data:image/s3,"s3://crabby-images/40287/402871dd7943b7a8a87a96e8f0d4396760c89deb" alt=""
打开具体对象可以查看对象属性信息,并更改
data:image/s3,"s3://crabby-images/9678d/9678de4d36a3a03f08a937e59572120565e65d4b" alt=""
网页添加Article对象
data:image/s3,"s3://crabby-images/5b6bd/5b6bd3cb46691457e20e393c675e8c33f3d5cb3f" alt=""
data:image/s3,"s3://crabby-images/c288e/c288eaab9b3dc4e137b513fb8514aa86e0a115ff" alt=""
可以看到新增的Article
data:image/s3,"s3://crabby-images/c7e1b/c7e1b0150f66a785ac5be3e126ea1a9316daf04e" alt=""
为了更好的查看模型数据,可以为Article模型类添加str魔法方法。
data:image/s3,"s3://crabby-images/7faef/7faefbba1257a8c1779b0cc270471a759b07bcd6" alt=""
data:image/s3,"s3://crabby-images/0d420/0d420f114a06f3e42cd62f4134fe0456a51d6858" alt=""
响应数据到前端
如果查询数据提示没有objects属性,需要开启django支持
data:image/s3,"s3://crabby-images/c755f/c755fa2f9fdac0a9abbe92268ee9d15dd3407bfa" alt=""
python如果导入不了自定义包,需要设置pycharm将当前项目定义为root目录
data:image/s3,"s3://crabby-images/42147/42147a98b596ceda60d8fbecd981c805f4eab8c2" alt=""
在blog增加视图渲染
from django.http import HttpResponse
from .models import Article
import json
Create your views here.
def blog_content(request):
articles = Article.objects.all()
article = articles[0]
title = article.title
brief_content = article.brief_content
content = article.content
id = article.article_id
date = article.publish
st = 'title: %s brief_contet: %s content: %s id %s date %s' %(title, brief_content, content, id, date)
return HttpResponse(st)
在blog应用注册path
data:image/s3,"s3://crabby-images/e7c49/e7c49c0bdfb1205de9fcadf59563e251c2f9ab7f" alt=""
在项目下注册path
data:image/s3,"s3://crabby-images/59fcd/59fcdc8e930c6ac72bd99d7ae994391bc238dacb" alt=""
网友评论