py库: django (web框架)

时间:2024-01-19 22:12:50

http://www.imooc.com/learn/736  Python-走进Requests库

http://www.imooc.com/learn/790  django入门与实践

http://www.imooc.com/learn/753  python-web.py开发入门(先不看)

https://www.imooc.com/learn/458  django初体检,本教程主要讲解Django基础入门知识

http://www.yiibai.com/django/django_quick_start_first_step.html#article-start  Django快速入门  2018-1-26

http://docs.30c.org/djangobook2/  django2.0文档

https://docs.djangoproject.com/en/2.0/releases/2.0/django2.0文档


环境:win7、python3.6.3、django2.0

  • django-admin  startproject   myproject  创建项目
  • cd  myproject
  • tree -f  (windows下看一下目录结构)
  • python manage.py   startapp  blog  创建应用
  • tree -f  (再看一下,已出现应用:blog)
myproject
│ db.sqlite3
│ manage.py # 管理项目:包括数据库建立、服务器运行、测试(manage.py是个大管家,做什么事情都要找它)

├─blog # (“应用”目录。 django中使用应用来分隔功能)
│ │ admin.py # admin相关                (此文件帮助您在管理界面中修改应用程序)
│ │ apps.py # 当前应用的一些配置(django1.9以后自动生成)
│ │ models.py # 定义数据库中的表             (存储所有的应用程序的模型)
│ │ tests.py # 测试相关                 (这是单元测试)
│ │ views.py # 响应用户请求,返回html页面        (这是应用程序视图)
│ │ __init__.py
│ │
│ └─migrations
│ __init__.py

└─myproject # (“项目”目录)
│ settings.py # 配置文件:应用、中间件、数据库、静态目录
│ urls.py # URL映射配置文件:决定一个url访问被哪个程序
│ wsgi.py # python应用程序或框架和Web服务器之间接口(目前用不到。以后要放在公网用nginx了,再做配置)----WSGI(Python Web Server Gateway Interface)python服务器网关接口
│ __init__.py

└─__pycache__
settings.cpython-36.pyc
urls.cpython-36.pyc
wsgi.cpython-36.pyc
__init__.cpython-36.pyc

创建应用后,需要把应用添加进去。

C:\Python3\myproject\myproject\settings.py

我们需要把它注册到myproject项目中,所以要更新 settings.py 文件的 INSTALLED_APPS 元组

#settings.py 的 40行,添加  blog

INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'blog',
]

另外,C:\Python3\myproject\myproject\settings.py的 26 行:  DEBUG = True  这是打开debug的开关

凡是和wsgi有关的都不用动它。

  • python manage.py runserver  运行django 服务    http://localhost:8000/
  • 或:python manage.py runserver  8080          http://localhost:8080/
  • 或:python manage.py runserver 0.0.0.0:8080    http://0.0.0.0:8080/
  • python manage.py  shell    进入SHELL
  • python manage.py                   查看有哪些命令(最常用的:runserver启动服务器;migrate makemigrations做好一个model后用这两条更新数据库表;shell。这4条命令是最常用的)
  • python manage.py createsuperuser  创建超级用户
  • python manage.py runserver             http://127.0.0.1:8000/admin/   用刚刚创建的超级用户登录

配置URL:

第一种配置URL:

C:\Python3\myproject\myproject\urls.py 此文件配置以下内容:

import blog.views as bv        # 可是为什么要这样写呢? 如果是z直接import blog,后面写 urlpatterns 怎么弄都不行。
urlpatterns = [
path('admin/', admin.site.urls),
path('blog/', bv.helloworld), # 要这样写
#url(r'blog/',bv.helloworld), # 这样写也行
]

C:\Python3\myproject\blog\views.py 此文件加入以下内容:

from django.shortcuts import render
from django.http import HttpResponse
def helloworld(request):
return HttpResponse('<html>hello111</html>')

第二种配置URL:

在根url.py中引入include

在APP目录下创建urls.py文件,各式与根urls.py相同

根urls.py中url函数第二个参数改为 include('blog.urls')

C:\Python3\myproject\myproject\urls.py  根urls配置如下:

from django.contrib import admin
from django.conf.urls import url, include
from django.urls import path urlpatterns = [
url('admin/', admin.site.urls),
url(r'blog/', include('blog.urls')),
]

C:\Python3\myproject\blog\urls.py  blog应用的urls配置如下:

from django.conf.urls import url, include
from . import views urlpatterns = [
url(r'^$',views.index), # 第一个参数是正则,所以用^开头,用$结尾,约束为是一个空字符串
url(r'^hello/$',views.hello), # 这里要注意一定要有 /
]

Models介绍:

ORM

对象关系映射(Object Relation Mapping)

实现了对象和数据库之间的映射

隐藏了数据访问的细节,不需要编写SQL语句

docs.djangoproject.com/en/1.10/ref/models/fields/  看官方文档

  • cd c:\Python3\myproject
  • python manage.py makemigrations  (参数 blog这个应用,如果不写参数的话,默认为生成该项目下所有应用的数据迁移)
  • python manage.py makemigrations  blog
  • python manage.py migrate
  • python manage.py sqlmigrate blog 0001

(python默认使用的数据库是 sqlite3,所以项目下有db.sqlite3这个文件。推荐使用第三方软件“SQLite Expert Personal”打开sqlite3数据库)


django概述:

1、URL配置:建立URL和与响应函数之间的关系
2、视图 Views:响应客户http请求,进行逻辑处理,返回给用户html页面
3、模型 Models:描述我们服务器存储的数据(数据库的表)
4、模板 templates: 用来生产html页面。返回给用户的html,是由数据(模型)和模板渲染出来的

https://www.imooc.com/video/8912  (这是简介性质的教程)2017-12-8

https://www.imooc.com/learn/790  继续看

django模板和vue模板,语法冲突的问题

使用verbatim标签解决冲突

自Django1.5以来,加入了 {% verbatim myblock %} {% endverbatim myblock %}标签,被此标签包裹的代码将不会被Django的模板引擎渲染。这样以来,我们可以把带有{{ }} 的Vue代码放在 {% verbatim myblock %}标签里,如下所示:

<div id="app">
{% verbatim myblock %}
{{ message }}
{% endverbatim myblock %}
</div>

...