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

Django菜鸟教程学习记录(一)创建项目django-admin.pystartprojectHelloWorld就会在当前目录下创建一个名为HelloWorld的文件夹。启动项目cdHelloWorldpython3manage.pyrunserver创建视图在helloworld的文件夹下新建一个views.py的文件并添加内容fromdjango.httpimportHttpResponsedefhello(request):returnHttpResponse(“Hello

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

创建项目

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>

进行访问,
在这里插入图片描述
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   # 创建表结构

个人踩坑
在执行第二个语句的时候一直提示如下错误在这里插入图片描述
在settings.py中将语言改成

LANGUAGE_CODE = 'zh-hans'

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

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

数据库的操作

用到再来写

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/195921.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号