Hello各位小伙伴,很久没有在简书上更新文章了,好久不见

去年的这个时候由于暑假比较无聊,便在微信上跟着一群小伙伴自学了Python Web开发框架Django,但由于当时代码功力尚浅(现在也浅),学了一段时间后还是有些晕,便一直没有继续学下去

碰巧这段时间开始实习,由于工作需要不得不重新拾起Django。花了两天时间重新学习,并将这个过程记录下来,一方面是方便自己以后随时回顾防止遗忘,另一方面希望能够帮助初学者开始自己的第一个Django项目,OK Let's Go!

1. 安装Django环境

打开cmd命令提示符,输入命令

pip install django==2.0.7

讲解: pip install 语法

通过==2.0.7 指定Django的版本号,也可以直接使用pip install django默认安装Django官方的最新版本

安装完成后,在cmd界面中输入以下命令验证是否安装成功

c:\users\lenovo>python -m django --version

若终端中显示出版本号,则说明安装成功

2. 创建你的第一个Django项目

1. 新建项目

打开cmd命令提示符,输入以下命令

#进入工作目录

C:\Users\Lenovo>cd C:\Users\Lenovo\PycharmProjects

#使用django-admin命令新建项目

C:\Users\Lenovo\PycharmProjects>django-admin startproject

此时,工作目录下已经创建出了Django的相关文件

目录说明:

investigation: 项目的容器。

manage.py: 一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互。

investigation/init.py: 一个空文件,告诉 Python 该目录是一个 Python 包。

investigation/settings.py: 该 Django 项目的设置/配置。

investigation/urls.py: 该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录"。

investigation/wsgi.py: 一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目

2. 启动服务

#切换到我们创建的项目

cd investigation

#使用manage.py启动服务

C:\Users\Lenovo\PycharmProjects\investigation>python manage.py runserver

.......

Starting development server at http://127.0.0.1:8000/

Quit the server with CTRL-BREAK

3. 视图(view)与 URL配置

1. 创建view

在之前创建的 investigation 目录下的 investigation 目录新建一个 view.py 文件,并输入代码

from django.http import HttpResponse

def hello(request):

return HttpResponse("Hello world ! ")

该段代码的作用是,当view接收到rerquest请求后,返回一句“Hello world ! ”的提示语

2. 将视图绑定到URL

打开investigation 目录下的 investigation 目录中的url.py 文件,并输入代码(模板中已经存在部分代码,请根据实际情况补充)

from django.contrib import admin

from django.urls import path

from django.conf.urls import url

from investigation import view

urlpatterns = [

path('admin/', admin.site.urls),

url(r'^/$, view.hello),

]

该段代码的作用是将先前创建好的视图(view)与URL进行绑定,当用户访问URL(http://127.0.0.1:8000)时,返回绑定好的视图函数

代码修改完成后重新启动Django服务,此时,访问http://127.0.0.1:8000即可看到网页端显示Hello World !

3. Django实战练习

这部分以在线表单为例,在Web端的表单中提交数据后,将数据保存到数据库中

1. 创建App

在investigation 目录下的 investigation 目录中打开cmd命令提示符,输入命令新建一个App

django-admin startapp myapp

此时,该目录下生成了一个新的文件夹myapp

讲解:Project和App的区别

一个Web项目可以理解为Project,比如我们创建了一个网站,在网站当中会有各种各样的功能、模块、业务。一个功能就可以是一个App,比如用户管理(User App)、文章管理(Article App)都是在一个Project当中不同的App。Project下面可以有很多Apps,Apps也可以属于不同的Project

2. 导入静态资源

在investigation目录的根下创建template目录,并将form.html和post.html文件复制到该目录中

在investigation目录的根下创建static文件夹

进入static文件夹中,创建css文件夹,并将style.css文件复制到该文件下

将下方代码复制粘贴到settings.py的最后

STATIC_URL = '/static/'

STATICFILES_DIRS = [

os.path.join(BASE_DIR,"static")

]

将以下代码填入settings.py第57行中括号中

os.path.join(BASE_DIR, 'templates')

讲解: django提供【django.contrib.staticfiles】来帮助你管理静态文件 静态文件包括:images, JavaScript, CSS 等 settings配置:STATIC_URL和STATICFILES_DIRS

3. 设计URL并编写views

打开App目录下(myapp目录)的views.py,将以下代码粘贴进去,定义一个视图函数

def showform(request):

return render(request, "form.html")

讲解:

该段代码定义了一个视图函数,当函数接收到request请求时,返回render函数,在本段代码中,即返回”form.html“页面

打开urls.py设计URL,将以下代码粘贴到该文件中

from django.contrib import admin

from django.urls import path

from django.conf.urls import url

from . import view

from investigation.myapp import views

urlpatterns = [

url(r'^$', view.hello),

url(r'^showform/$', views.showform)

]

保存编辑完成的代码,重新启动Django服务,若出现以下界面,则说明这一阶段部署成功

4691967d8679?from=groupmessage

4. 提交并保存数据

在本机安装MySQL客户端,后期我们会将数据保存到MySQL数据库中

在本机安装Navicat For MySQL

新建数据库djangoPro

进入djangoPro中新建数据表userinfo,建表SQL语句如下

CREATE TABLE `userinfo` (

`qq_id` varchar(20) DEFAULT NULL,

`wx_id` varchar(20) DEFAULT NULL,

`stu_name` varchar(100) DEFAULT NULL,

`gender` varchar(1) DEFAULT NULL,

`age` int(3) DEFAULT NULL,

`major` varchar(30) DEFAULT NULL,

`hobby` varchar(100) DEFAULT NULL,

`python_level` varchar(10) DEFAULT NULL,

`is_new` varchar(100) DEFAULT NULL,

`has_book` varchar(100) DEFAULT NULL

) ENGINE=InnoDB DEFAULT CHARSET=utf8

使用pip命令安装pymysql

pip isntall pymysql

讲解:

pymysql 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用MySQLdb

打开investigation目录下的init.py文件,写入以下代码

import pymysql

pymysql.install_as_MySQLdb()

讲解:

由于兼容性问题,Django暂不支持直接使用pymysql,此步骤的代码是将Django默认的数据库连接库MySQLdb更换为pymysql

打开App目录下(myapp目录)的views.py,编写数据库链接函数connect_database()和数据存储函数savedata()

import pymysql

def connect_database():

mysql_conn = {

'host': 'localhost',

'port': 3306,

'user': 'root',

'password': 'password',

'db': 'djangoPro',

'charset': 'utf8'

}

db = pymysql.connect(**mysql_conn)

cursor = db.cursor()

return db

def savedata(qq_id, wx_id, stu_name,

gender, age, major, hobby,

python_level, is_new, book_info):

db = connect_database()

cursor = db.cursor()

cursor.execute("INSERT INTO userinfo VALUES (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)",

(qq_id, wx_id, stu_name, gender, age,

major, hobby, python_level, is_new, book_info))

db.commit()

db.close()

在views.py里编写保存表单的函数saveform()

def saveform(request):

qq_id = request.POST['qq_id']

wx_id = request.POST['wx_id']

stu_name = request.POST['nick_name']

gender = request.POST['gender']

age = request.POST['age']

major = request.POST['major']

hobby = request.POST['hobby']

python_level = request.POST['python_level']

is_new = request.POST['is_new']

book_info = request.POST['book_info']

savedata(qq_id, wx_id, stu_name, gender, age, major, hobby, python_level, is_new, book_info)

return render(request, "post.html")

在urls.py中添加一条路由记录,绑定saveform的视图

url(r'^saveform/$', views.saveform)

保存相关代码,重新启动Django服务

此时,进入到数据库中,就能看到表单提交的数据了

流程讲解:

保存数据这部分的代码让人有些凌乱,我们来拆分一下程序实现的流程

当你在showform页面点击提交按钮的一瞬间,一条数据被POST到了我们的服务器

通过Firefox浏览器抓包,我们可以看到这条数据长这样

4691967d8679?from=groupmessage

程序将这条数据作为参数(request)传递给views.py中的saveform()函数

Django提供了request.POST的方法获得post请求发出的数据,将表单中的数据逐一提取出来,并赋值给变量

数据提取出来后,调用savedata()函数,将数据写入数据库

数据存储成功

结束语

至此,Django实战入门简易教程就结束了,第一次写这么长的文章,写得不好还请多多指教

有些人看完可能要说了,Django提供了models.py,通过ORM存储数据更加简单,为什么还要用pymysql这么原始笨拙的方法

是产品经理逼我这样写的

Emmm.....不对!其实是我们产品经理用心良苦,他觉得对于初学者来说还是用最原始的办法会好一些,ORM虽方便,但是万一中途出现报错,初学者会无从下手(比如我),所以建议对Django框架有了一个大致的了解后,再去自行学习models.py的用法

Good Luck !