Django---MTV模型、基本命令、简单配置

前端之家收集整理的这篇文章主要介绍了Django---MTV模型、基本命令、简单配置前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

MTV模型

  

Django的MTV分别代表:

Model(模型):负责业务对象与数据库的对象(ORM)

Template(模版):负责如何把页面展示给用户

View(视图):负责业务逻辑,并在适当的时候调用Model和Template

此外,Django还有一个urls分发器,它的作用是将一个个URL的页面请求分发给不同的view处理,view再调用相应的Model和Template

Django基本命令

1、下载Django:

Highlighter sh-gutter">
Highlighter_363378" class="SyntaxHighlighter python">

2、创建一个django project

Highlighter sh-gutter">
Highlighter_489767" class="SyntaxHighlighter python">

当前目录下会生成mysite的工程,目录结构如下:

  • 调用djangoshell和数据库等。
  • 包括数据库信息,调试标志以及其他一些工作的变量。

3、在mysite目录下创建应用

Highlighter sh-gutter">
Highlighter_567348" class="SyntaxHighlighter python">

4、启动django项目

Highlighter sh-gutter">
Highlighter_602940" class="SyntaxHighlighter python">

这样我们的django就启动起来了!当我们访问:http://127.0.0.1:8080/时就可以看到:

5、同步更改数据库表或字段

注意:Django 1.7.1 及以上的版本需要用以下命令 python manage.py makemigrations python manage.py migrate

<span style="color: #800000;">'''

这种方法可以创建表,当你在models.py中新增了类时,运行它就可以自动数据库中创建表了,不用手动创建。

生成我们的表,可能是settings文件中没有注册我们的app,需要我们手动去注册

INSTALLED_APPS = ]

6、清空数据库

Highlighter sh-gutter">
Highlighter_379860" class="SyntaxHighlighter python">

此命令会询问是 yes 还是 no,选择 yes 会把数据全部清空掉,只留下空表。

7、创建超级管理员

# 按照<a href="/tag/tishi/" target="_blank" class="keywords">提示</a>输入<a href="/tag/yonghuming/" target="_blank" class="keywords">用户名</a>和对应的密码就好了邮箱可以留空,<a href="/tag/yonghuming/" target="_blank" class="keywords">用户名</a>和密码必填 # <a href="/tag/xiugai/" target="_blank" class="keywords">修改</a> <a href="/tag/yonghu/" target="_blank" class="keywords">用户</a>密码可以用: python manage.py changepassword username

<span style="color: #800000;">'''

8、Django 项目环境终端

Highlighter sh-gutter">
Highlighter_568274" class="SyntaxHighlighter python">

这个命令和 直接运行 python 进入 shell 的区别是:你可以在这个 shell 里面调用当前项目的 models.py 中的 API,对于操作数据的测试非常方便。

9、Django 项目环境终端

ython manage.py dbshell

Django 会自动进入在settings.py中设置的数据库,如果是 MysqL 或 postgresql,会要求输入数据库用户密码。

在这个终端可以执行数据库sql语句。如果您对sql比较熟悉,可能喜欢这种方式。

10、更多命令

Highlighter sh-gutter">
Highlighter_363453" class="SyntaxHighlighter python">

查看所有的命令,名称的时候特别有用。

文件配置

1.静态文件配置

静态文件的处理又包括STATIC和MEDIA两类,这往往容易混淆,在Django里面是这样定义的:
    MEDIA:指<a href="/tag/yonghu/" target="_blank" class="keywords">用户</a><a href="/tag/shangchuan/" target="_blank" class="keywords">上传</a>的<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>,比如在Model里面的FileFIeld,ImageField<a href="/tag/shangchuan/" target="_blank" class="keywords">上传</a>的<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>。如果你定义

    MEDIA_ROOT=c:\temp\media,那么File=models.FileField(upload_to="abc/")#,<a href="/tag/shangchuan/" target="_blank" class="keywords">上传</a>的<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>就会被保存到c:\temp\media\abc

    eg:
        class blog(models.Model):
               Title=models.charField(max_length=64)
               Photo=models.ImageField(upload_to="photo")
      <a href="/tag/shangchuan/" target="_blank" class="keywords">上传</a>的<a href="/tag/tupian/" target="_blank" class="keywords">图片</a>就<a href="/tag/shangchuan/" target="_blank" class="keywords">上传</a>到c:\temp\media\photo,而在模板中要<a href="/tag/xianshi/" target="_blank" class="keywords">显示</a>该<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>,则在这样写
      在settings里面设置的MEDIA_ROOT必须是本地路径的<a href="/tag/jueduilujing/" target="_blank" class="keywords">绝对路径</a>,一般是这样写:
             BASE_DIR= os.path.abspath(os.path.dirname(__file__))
             MEDIA_ROOT=os.path.join(BASE_DIR,'media/').replace('\\','/')

    MEDIA_URL是指从浏览器访问时的地址前缀,举个例子:
        MEDIA_ROOT=c:\temp\media\photo
        MEDIA_URL="/data/"
    在开发阶段,media的处理由django处理:

       访问http://localhost/data/abc/a.png就是访问c:\temp\media\photo\abc\a.png

       在模板里面这样写<img src="/media/abc/a.png"&gt;

       在部署阶段最大的不同在于你必须让web服务器来处理media<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>,因此你必须在web服务器中配置,
       以便能让web服务器能访问media<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>
       以<a href="/tag/Nginx/" target="_blank" class="keywords">Nginx</a>为例,可以在<a href="/tag/Nginx/" target="_blank" class="keywords">Nginx</a>.conf里面这样:

             location ~/media/{
                   root/temp/
                   break;
                }

       具体可以参考如何在<a href="/tag/Nginx/" target="_blank" class="keywords">Nginx</a>部署django的资料。


       </span><span style="color: #800000;"&gt;'''</span></pre>

<div class="cnblogs_code">

 <a href="/tag/jingtaiwenjian/" target="_blank" class="keywords">静态文件</a>交由Web服务器处理,Django本身不处理<a href="/tag/jingtaiwenjian/" target="_blank" class="keywords">静态文件</a>。简单的处理逻辑如下(以<a href="/tag/Nginx/" target="_blank" class="keywords">Nginx</a>为例):

          URI请求</span>-----><span style="color: #000000;"&gt; 按照Web服务器里面的配置规则先处理,以<a href="/tag/Nginx/" target="_blank" class="keywords">Nginx</a>为例,主要求配置在<a href="/tag/Nginx/" target="_blank" class="keywords">Nginx</a>.
                         conf里的location

                     </span>|----------><span style="color: #000000;"&gt;如果是<a href="/tag/jingtaiwenjian/" target="_blank" class="keywords">静态文件</a>,则由<a href="/tag/Nginx/" target="_blank" class="keywords">Nginx</a>直接处理

                     </span>|----------><span style="color: #000000;"&gt;如果不是则交由Django处理,Django根据urls.py里面的规则进行匹配

以上是部署到Web服务器后的处理方式,为了便于开发,Django提供了在开发环境的对<a href="/tag/jingtaiwenjian/" target="_blank" class="keywords">静态文件</a>的处理机制,<a href="/tag/fangfa/" target="_blank" class="keywords">方法</a>是这样:</span></pre>

static配置:

STATIC主要指的是如css,js,images这样文件

STATIC_URL = STATICFILES_DIRS =) 文件夹的名字,这里的逗号必须加,否则会报错! <span style="color: #800000;">'''<span style="color: #800000;">

注意点1:
django对引用名和实际名进行映射,引用时,只能按照引用名来,不能按实际名去找,如
<script src="/statics/jquery-3.1.1.js">
------error-----不能直接用实际名,
必须用STATIC_URL = '/static/':
<script src="/static/jquery-3.1.1.js">
     -----success------必须用引用名static,为了避免错误,最好,文件夹名取名为static,保持一致,记得要放在根目录下和templates一样
注意点2:
STATICFILES_DIRS = (
("app01",os.path.join(BASE_DIR,"app01/statics")),)

<script src="/static/app01/jquery.js">

<span style="color: #800000;">'''

have a try:

http://127.0.0.1:8000/static/jquery.js

media配置:

==os.path.join(BASE_DIR,,,<span style="color: #008000;">#<span style="color: #008000;"> in urls:
<span style="color: #0000ff;">from
django.views.static <span style="color: #0000ff;">import
<span style="color: #000000;"> serve
url(r
<span style="color: #800000;">'
<span style="color: #800000;">^media/(?P.*)$
<span style="color: #800000;">'
,serve,{<span style="color: #800000;">'
<span style="color: #800000;">document_root
<span style="color: #800000;">'
: settings.MEDIA_ROOT}),

have a try:

http://127.0.0.1:8000/media/1.png

2.其他配置

模板路径配置(给render用)

: [os.path.join(BASE_DIR,自动找到模板路径下的文件

数据库配置

Django默认使用sql,在settings中是

DATABASES =: sqlite3: os.path.join(BASE_DIR,sqlite3

如果要使用MysqL,则需要把settings里的配置进行修改

DATABASES =</span><span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;default</span><span style="color: #800000;"&gt;'</span><span style="color: #000000;"&gt;: { </span><span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;ENGINE</span><span style="color: #800000;"&gt;'</span>: <span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;django.db.backends.<a href="/tag/MysqL/" target="_blank" class="keywords">MysqL</a></span><span style="color: #800000;"&gt;'</span><span style="color: #000000;"&gt;,</span><span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;NAME</span><span style="color: #800000;"&gt;'</span>: <span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;newBlog</span><span style="color: #800000;"&gt;'</span>,<span style="color: #008000;"&gt;#</span><span style="color: #008000;"&gt;你的<a href="/tag/shujuku/" target="_blank" class="keywords">数据库</a><a href="/tag/mingcheng/" target="_blank" class="keywords">名称</a></span> <span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;USER</span><span style="color: #800000;"&gt;'</span>: <span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;root</span><span style="color: #800000;"&gt;'</span>,<span style="color: #008000;"&gt;#</span><span style="color: #008000;"&gt;你的<a href="/tag/shujuku/" target="_blank" class="keywords">数据库</a><a href="/tag/yonghuming/" target="_blank" class="keywords">用户名</a></span> <span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;PASSWORD</span><span style="color: #800000;"&gt;'</span>: <span style="color: #800000;"&gt;''</span>,<span style="color: #008000;"&gt;#</span><span style="color: #008000;"&gt;你的<a href="/tag/shujuku/" target="_blank" class="keywords">数据库</a>密码</span> <span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;HOST</span><span style="color: #800000;"&gt;'</span>: <span style="color: #800000;"&gt;''</span>,<span style="color: #008000;"&gt;#</span><span style="color: #008000;"&gt;你的<a href="/tag/shujuku/" target="_blank" class="keywords">数据库</a>主机,留空默认为localhost</span> <span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;PORT</span><span style="color: #800000;"&gt;'</span>: <span style="color: #800000;"&gt;'</span><span style="color: #800000;"&gt;3306</span><span style="color: #800000;"&gt;'</span>,<span style="color: #008000;"&gt;#</span><span style="color: #008000;"&gt;你的<a href="/tag/shujuku/" target="_blank" class="keywords">数据库</a>端口</span>

<span style="color: #000000;">
}

}

并且在__init__.py中写上点东西

MysqL

pyMysqL.installasMysqLdb()

完成以上配置,即可使用MysqL数据库

自动打印对应的sql语句

当我们使用ORM时,想自动打印对应的sql语句,可以在settings中加上下面的配置

LOGGING =: 1::: [:
sql语句

dio controls="controls" style="display: none;">

猜你在找的Django相关文章