Django菜鸟教程学习记录(一)

创建项目

django-admin.py startproject HelloWorld

就会在当前目录下创建一个名为HelloWorld的文件夹。

启动项目

cd HelloWorld
python3 manage.py runserver

创建视图

在helloworld的文件夹下新建一个views.py的文件并添加内容

from django.http import HttpResponse
 
def hello(request):
    return HttpResponse("Hello world ! "

并打开urls.py的文件写入

from django.conf.urls import url
 
from . import views
 
urlpatterns = [
    url(r'^$', views.hello),
]

这时候访问http://127.0.0.1:8000/便可以访问到HelloWorld

Django模板

在项目内新建一个templates文件夹并创建一个runoob.html的文件

<h1>{{ hello }}</h1>

向Django说明模板文件的路径,修改HelloWorld/settings.py,修改 TEMPLATES 中的 DIRS 为

'DIRS': [BASE_DIR / "templates"],

在views.py添加新的内容

from django.shortcuts import render

def runoob(request):
    context ={}
    context['hello'] = 'Hello World!'
    return render(request,'runoob.html',context)

有了方法之后,要在urls.py内添加新的路径

from . import views

urlpatterns = [
    
    path('runoob/', views.runoob),
]

在runoob的页面中添加了hello这个变量,然后在view用context进行承接,并将其赋值为Hello World!,然后在 利用render进行渲染。就实现了数据和视图分离。
而在真正的使用过程中,应该是这样的:

def runoob(request):
    views_name = "我在view内进行赋值"
    return render(request,'runoob.html',{"hello":views_name})

也可以支持类似数组的写法在runoob.html页面内进行定义
views.py:


def runoob(request):
    views_array = ["元素1","元素2","元素3"]
    return render(request,'runoob.html',{"hello":views_array})

runoob.html

<h1>{{ hello  }}</h1>
<h2>{{ hello.1}}</h2>

进行访问,
Django菜鸟教程学习记录(一)
templates 中的 runoob.html中,可以用 .键 取出对应的值。

先在view.py中进行赋值

def runoob(request):
    views_array = {"name":"我是name值"}
    return render(request,'runoob.html',{"hello":views_array})

在runoob.html中取值

<h1>{{ hello  }}</h1>
<h2>{{ hello.name}}</h2>

…未完待续

Django数据库Mysql

首先需要有一个数据库runoob
并在setting.py中修改信息

DATABASES = { 
    'default': 
    { 
        'ENGINE': 'django.db.backends.mysql',    # 数据库引擎
        'NAME': 'runoob', # 数据库名称
        'HOST': '127.0.0.1', # 数据库地址,本机 ip 地址 127.0.0.1 
        'PORT': 3306, # 端口 
        'USER': 'lqy',  # 数据库用户名
        'PASSWORD': 'qwe123', # 数据库密码
    }  
}

并在__init__.py中引入模块和进行配置

import pymysql
pymysql.install_as_MySQLdb()

新建一个TestModel应用来应用这个模 型

django-admin.py startapp TestModel

在TestModel的models.py中新建一个类

class Test(models.Model):
    name = models.CharField(max_length=20)

其中Test为类名 == 数据库的表名且继承了models.Model。
name就相当于数据库的列名 属性为char
接下来在 settings.py 中找到INSTALLED_APPS这一项,在最后添加上

INSTALLED_APPS = [

'TestModel', 
}

在终端运行

$ python3 manage.py migrate   # 创建表结构

$ python3 manage.py makemigrations TestModel  # 让 Django 知道我们在我们的模型有一些变更
$ python3 manage.py migrate TestModel   # 创建表结构

个人踩坑
在执行第二个语句的时候一直提示如下错误Django菜鸟教程学习记录(一)
在settings.py中将语言改成

LANGUAGE_CODE = 'zh-hans'

#__init__.py这个页面中添加第二行
import pymysql
pymysql.version_info = (1, 4, 0, "final", 0)
pymysql.install_as_MySQLdb()

以上我们就完成了数据库的创建。

数据库的操作

用到再来写

上一篇:vue中过滤空格


下一篇:eclipse中的javac命令与java命令