s10_part3_django_basic.md

```https://www.bilibili.com/video/av24702867/?p=337
```
[TOC]
#django安装

```
mkdir -p ~/PycharmProjects/project/Django2.0
cd ~/PycharmProjects/project/Django2.0
virtualenv mysite-env
source mysite-env/bin/activate
pip install django==1.11.11
pip list
deactivate #退出虚拟环境
```
#初步创建django项目mysite

##startproject
```
django-admin startproject mysite
tree mysite

mysite/
├── manage.py
└── mysite
    ├── __init__.py
    ├── settings.py
    ├── urls.py
    └── wsgi.py

```

##初识mysite.mysite.urls.py
cat urls.py

```
from django.conf.urls import url
from django.contrib import admin

#为了避免自己写http协议的socket,这里直接引用 django的HttpResponse
from django.shortcuts import HttpResponse

def test_url(request):  #自定义一个函数,request代表所有的http请求,可以是任务字符,通常习惯上使用request
    return HttpResponse("hello world!")   #返回一串字符

urlpatterns = [
    # url(r‘^admin/‘, admin.site.urls),
    url(r‘^test_url/‘, test_url),
]

```

##启动django服务器
命令行中输入python manage.py runserver //启动服务器
再浏览器中输入:http://127.0.0.1:8000/test_url/
即可到返回的字符串:hello world!

##mysite.mysite.settings.py

```
settings.py中默认存在:BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

所有的html相关文件的设置都在这里
注意:填写DIRS采用这种内置函数的方式   ‘DIRS‘: [os.path.join(BASE_DIR,‘templates‘)],
不要使用字符串拼接,因为不确定运行的操作系统的路径分隔符
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‘,
            ],
        },
    },
]
```
所以在BASEDIR(即这里的mysite)下新建一个文件夹templates,然后将html文件放置于这个文件夹中即可

##使用render返回网页

cat urls.py
```
from django.conf.urls import url
from django.contrib import admin

#为了避免自己写http协议的socket,这里直接引用 django的HttpResponse
from django.shortcuts import HttpResponse, render

def test_url(request):  #自定义一个函数,request代表所有的http请求,可以是任务字符,通常习惯上使用request
    return HttpResponse("hello world!")   #返回一串字符

def test_url2(request):
    return render(request,"url2.html")  #返回html文件

    #如果url2.html的位置是在templates下的某一个文件夹XX
    #那么改为:return render(request,"xx/url2.html") 即可

# 返回渲染的html与以下读取文件,返回字符串的效果相同
def test_url3(request):
    # with open("xx/url2.html",‘rb‘) as f:   #等价于下一写法
    with open("xx/url2.html",‘r‘,encoding=‘utf-8‘) as f:
        data = f.read()
    return HttpResponse(data)  

urlpatterns = [
    # url(r‘^admin/‘, admin.site.urls),
    url(r‘^test_url/‘, test_url),   #前面部分为访问的url,后面为调用的函数名
    url(r‘^test_url2/‘, test_url2),
    url(r‘^test_url3/‘, test_url3),
]

```
##静态文件配置项STATICFILES_DIRS

默认此项配置位于settings.py的最后

```
#此项是静态文件保存目录的别名
STATIC_URL = ‘/static/‘

#添加如下静态文件项,将所有的静态文件(js,css,images)都放在下面配置的路径中

STATICFILES_DIRS = [
os.path.join(BASE_DIR,"static")

]

```

##startapp

```
cd mysite
python manage.py startapp blog

tree mysite
mysite/
├── blog
│   ├── admin.py
│   ├── apps.py
│   ├── __init__.py
│   ├── migrations
│   │   └── __init__.py
│   ├── models.py
│   ├── tests.py
│   └── views.py
├── manage.py
└── mysite
    ├── __init__.py
    ├── settings.py
    ├── urls.py
    └── wsgi.py

```

##帮助命令

```

python manage.py help //查看帮助命令
python manage.py migrate //初始化默认数据库
python manage.py createsuperuser //创建超级管理员

```

  

原文地址:https://www.cnblogs.com/rootid/p/9814042.html

时间: 2024-10-27 12:43:47

s10_part3_django_basic.md的相关文章

GitHub上README.md教程

转自:http://blog.csdn.net/kaitiren/article/details/38513715#t0 最近对它的README.md文件颇为感兴趣.便写下这贴,帮助更多的还不会编写README文件的同学们. README文件后缀名为md.md是markdown的缩写,markdown是一种编辑博客的语言.用惯了可视化的博客编辑器(比如CSDN博客,囧),这种编程式的博客编辑方案着实让人眼前一亮.不过GitHub支持的语法在标准markdown语法的基础上做了修改,称为Githu

MD、EVA、PU、PVC、TPU、DPU

RB.PU.PVC.TPU.TPR.TR, EVA .MD . DPU DPU是一种耐磨.韧性好的工程塑料,不比EVA或橡胶底或牛筋底差,但其质量比以上都轻,但易刺破不易攀岩 1.先说什么是MD:MODEL或PHYLON飞龙的统称 2.那么什么是PHYLON:(俗称飞龙)是一种做鞋底的材料一般制鞋用的中底, 用加热压缩的EVA发泡制成的混合物质.(属EVA二次高压成型品)特点质轻, 弹性及抗震性能好, 硬度是由发泡温度控制的. 3.那么什么是EVA:Ethylene Vinyl Acetate-

(转)VC运行库MD /MDd /MT /MTd /ML /MLd

VC编译选项 - 多线程(/MT) - 多线程调试 (/MTd) - 多线程DLL (/MD) - 多线程调试DLL (/MDd) C 运行时库 库文件 - Single thread(static link) ML libc.lib - Debug single thread(static link) MLd libcd.lib - MultiThread(static link) MT libcmt.lib - Debug multiThread(static link) MTd libcm

README.md文件 github Markdown语言详解 md文件用法和说明

本人使用.md文档完全为了记录日常的编译和工作中遇到的问题,需要用到的功能大概就是常用的语法,强调,引用,代码,链接等.对于图片的插入需求不高,因此本文主要介绍一些语法特点,最后涉及一点可能用到的其他功能. 000-->功能函数详细条目: 区块元素 段落和换行 一个 Markdown 段落是由一个或多个连续的文本行组成,它的前后要有一个以上的空行(空行的定义是显示上看起来像是空的,便会被视为空行.比方说,若某一行只包含空格和制表符,则该行也会被视为空行).普通段落不该用空格或制表符来缩进. 「由

如何在MD(d)和MT(d)工程间正确分配和释放动态内存

MD(d)和MT(d) MD(d)和MT(d)是windows下VC开发的两个编译选项,表示程序的运行时库编译选项. /MT是"multithread, static version" 意思是多线程静态的版本,定义了它后,编译器把LIBCMT.lib安置到OBJ文件中,让链接器使用LIBCMT.lib 处理外部符号. /MD是"multithread- and DLL-specific version",意思是多线程DLL版本,定义了它后,编译器把MSVCRT.li

Markdown语法学习(Github/git.oschina.net上README.md书写规范)(转)

晚上在更新git.oschina.net项目时,突然想知道README.md后缀的来源,于是搜了下,发现README.md使用了一种小标记语言Markdown的语法,于是简单的看了一个,特转载如下,为了下次参考方便(http://blog.csdn.net/kaitiren/article/details/38513715也不错).中文参考手册可以参考http://wowubuntu.com/markdown/index.html Markdown 的目标是实现「易读易写」,兼容HTML. 但是

.md即markdown文件的基本常用编写语法(图文并茂)

序言: 很久没有写博客了,感觉只要是不写博客,人就很变得很懒,学的知识点感觉还是记不住,渐渐地让我明白,看的越多,懂的越少(你这话不是有毛病吗?应该是看的越多,懂的越多才对),此话怎讲,当你在茫茫的前端知识库里面东看看,西看看的时候,很快就被海量的知识给淹没了,根本就不知道哪些是对的,哪些是错的,感觉好像这个也懂了,那个也懂了,但是真正写起来,脑子又一片空白,又好像什么都不懂,这种状态时有发生,这就叫不懂装懂,最根本的原因就是看的太多,写的太少,所以为了改掉这样毛病,把被动学习变成主动学习,接下

VS运行时 /MD、/MDd 和 /MT、/MTd之间的区别

程序运行时出现问题,选择的是Release,win64位的模式,并且已经看到了宏定义NDEBUG,但是程序依然进入上面的部分 解决方案是将属性->C/C++->代码生成器->运行库里面的多线程调试(/MTD)修改为多线程DLL(/MD)即可 修改之后: 编译一下 解释原因来自 http://blog.csdn.net/u013829933/article/details/50321355,感谢~~ 这里总结下他们的区别,后面的那个'd'是代表DEBUG版本,没有'd'的就是RELEASE

关于github中的README.md文件

0x01 README.md文件是用Markdown语言编写的,md=Markdown; 在线编辑工具: https://stackedit.io/editor# https://maxiang.io/#笔记本和标签 关于使用语法的说明: https://github.com/guoyunsky/Markdown-Chinese-Demo 0x02 Markdown 是一种轻量级的「标记语言」,它的优点很多,目前也被越来越多的写作爱好者,撰稿者广泛使用.看到这里请不要被「标记」.「语言」所迷惑,