记录一次完整的基于django的实例

本实例来自慕课网实战课程《强力django+杀手级xadmin 打造上线标准的在线教育平台》,超级好的一个课程,建议支持购买学习。购买连接:<a>http://coding.imooc.com/class/78.html</a>

实例内容:
一个简单的将前端页面数据提交到数据库,从数据库取出数据展示到前端页面。

环境:
win10 + pycharm + python3.5 + django1.10

项目配置流程:
安装pymysql→Settings配置→(databases,templates下的dirs,新建statixfiles_dirs)→migration生成数据表→编写views.py→配置urls.py→(1.HTNL个css文件分离,2.css文件分离与地址修改)

第一步:创建项目djangostart

Paste_Image.png

第二步:创建app-> message

首先按照图所示,调出运行窗口

Paste_Image.png

然后在窗口中输入:startapp message
这时会生成对应的app,并将app添加到setting配置文件。

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

    'message',
]

第三步:创建static目录,用于存放静态文件(CSS,JS等文件)

Paste_Image.png

至此我们已经创建好项目的基本目录。

第四步:将前端页面配置到模板,将CSS文件配置到static目录

目录结构为

前端页面代码逻辑为;

<head>
    <meta charset="UTF-8">
    <title></title>
    <link rel="stylesheet" href="/static/css/style.css">
</head>

第五步:配置setting文件中的静态文件和模板文件路径

当配置好第四步之后,我们如果运行程序不会加载出页面,因为我们需要配置文件路径。
对于静态文件:

STATIC_URL = '/static/'
#仅有上面的设置,只说明了样式放在static文件,需要指定和项目根目录的关系

#设置静态文件的目录,设置为列表形式
STATICFILES_DIRS = [
    os.path.join(BASE_DIR,'static')
]

对于模板文件:

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        #根据根目录设置templates目录
        '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',
            ],
        },
    },
]

其中的BASE_DIR为当前目录的绝对路径

import os

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
#获取当前目录的绝对路径
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

配置完这两项,我们就可以加载出页面,否则加载不出。

第六步:配置django连接mysql数据库

因为我们的项目是需要连接数据库的,因此我们需要配置连接数据库。
python3连接MySQL不再使用MySQLdb,现在大部分都是使用PyMySQL用于连接MySQL数据库。
首先安装PyMySQL用于替代MySQLdb。
然后在工程目录的init.py中填写下面两句话

import pymysql
pymysql.install_as_MySQLdb()

接着配置setting文件,连接数据库

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', #主要是这里,将默认的sqlite3改为mysql
        'NAME': "testdjango", #数据库的名字
        'USER': "root",#数据库用户名
        'PASSWORD': "root",#数据库密码
        'HOST': "127.0.0.1",数据库地址,默认本机
        'PORT': "",数据库端口,默认3306
    }
}

配置好数据库之后,可以根据django来生成默认的数据表。
同样是在Tools -> Run manage.py Task 打开运行窗口
我们运行makemigrations(检查要修改的数据库字段),migrate(生成数据表)
当运行完上述两个命令之后,就会在数据库中创建一些默认的基本数据表。

第七步:配置urls.py和views.py

在views.py中配置函数

def getform(request):
    return  render(request,'message.html')

在urls.py中配置url映射

from django.conf.urls import url
from django.contrib import admin
from message.views import getform

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^form/$',getform,name='go_form')
]

配置好以上两个文件,我们就可以调试程序了,Run -> Debug
然后在浏览器中输入:<a>http://127.0.0.1:8000/form/</a>

Paste_Image.png

第八步:django model层的配置

我们使用django的ORM机制,使类和数据库里的表相对应。
我们在models.py中进行以下配置:

# Create your models here.
class UserMessage(models.Model):
    object_id = models.CharField(primary_key=True,verbose_name=u"主键",max_length=20,default="")
    name = models.CharField(max_length=20,null=True,blank=True,default="",verbose_name=u"用户名")
    email = models.EmailField(verbose_name=u"邮箱")
    address = models.CharField(max_length=100,verbose_name=u"联系地址")
    message = models.CharField(max_length=500,verbose_name=u"留言信息")

    class Meta:
        verbose_name = u"用户留言信息"
        verbose_name_plural = verbose_name
        #指定数据库的表名
        #db_table = "user_message"
        #排序
        #ordering = "-object_id"

根据前端页面表单的数据,我们创建了四个属性。
里面的object_id 为主键。
配置好之后,我们配置生成数据表,Tools -> Run manage.py Task 打开运行窗口:

makemigrations  message
之后运行
migrate message

我们可以通过navicat查看生成的数据表:

Paste_Image.png

第九步:通过ORM对数据库进行增删改查

首先我们在views.py中引用我们刚才创建的类

from .models import UserMessage

如何获取数据库中的数据:
我们通过类UserMessage的数据表管理器objects获取数据。

获取数据库的所有数据,返回的是可以进行循环的QuerySet类型    数据表管理器objects
all_message = UserMessage.objects.all()
for message in all_message:
    print(message.name)
这里的message其实就是UserMessage的实例
我们还可以根据条件取出数据
all_message = UserMessage.objects.filter(name=u"王二小",address=u"杭州")

如何删除数据:
我们可以使用delete()函数删除所取的值

all_message = UserMessage.objects.all()
#删除所有
#all_message.delete()
for message in all_message:
    #删除单一值
    #message.delete()

如何往数据库里面添加数据:
我们通过实例化UserMessage对象,通过属性赋值,通过save()方法往数据库里赋值。

user_message = UserMessage()
user_message.name = u"王小二"
user_message.message = u"放羊娃"
user_message.address = u"杭州"
user_message.object_id = "2"
user_message.email = "2@2.com"
user_message.save()

完成上面的代码之后,我们运行项目,然后刷新页面,这时数据将会保存进数据库。

如何提取前端页面表单中的数据保存到数据库中:
我们使用POST将表单数据提交。

#首先判断request的方式
if request.method == "POST":
    #通过request的get()函数,获得提交的值
    name = request.POST.get('name','')#当属性值不存在,则赋空值
    message = request.POST.get('message','')
    email  = request.POST.get('email','')
    address = request.POST.get('address','')

    user_message = UserMessage()
    user_message.name = name
    user_message.message = message
    user_message.address = address
    user_message.object_id = "3" #这里的主键我们随便设置
    user_message.email = email

    #将值保存到数据库
    user_message.save()

我们提交的数据都保存在POST中,通过get方法获得。
代码中get('name','')这里的name是前端页面表单里面name="name"的name。

想要完成数据的提交在前端页面要有下面两项配置:

<form action="/form/}" method="post" class="smart-green">

以及表单的提交允许

    #加了csrf_token之后才能够往后台提交数据
    {% csrf_token %}

完成上面的代码配置之后,运行调试,然后在表单中输入数据然后提交,数据被保存到数据库中。

如何将数据库中的数据显式到前端页面中:
通过render()方法,添加字典形式的参数。

    #将后台数据库里的数据提取到前端页面
    message = None
    all_message = UserMessage.objects.filter(name=u"王二小")
    返回的Queryset可以做切片操作
    if all_message:
        message = all_message[0]

    return  render(request,'message.html',{"my_message":message})

在前端页面中,我们使用的是字典的键。
在前端页面的调用:

value="{{ my_message.name }}"

好了,至此为止,我们基本完成了一个简单的表单提交(里面有很多坑)。还有url的命名等其它知识,欢迎包名学习《强力django+杀手级xadmin 打造上线标准的在线教育平台》,超级好的一个课程,建议支持购买学习。购买连接:<a>http://coding.imooc.com/class/78.html</a>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容