前言

以下项目实现基于一个投票系统

安装django

命令行安装

pip install django

pycharm安装

pycharm的setting里找到这个,点击+号,搜索django



点击Install Package

新建一个django项目

命令行创建项目(windows)

在pip安装完之后,在python的Scripts目录里有 django-admin.exe



:::tips

django-admin.exe startproject [项目名称]

:::



目录结构是这样

命令行创建项目(linux)

python3 -m django startproject my_django[项目名称] 或者 django-admin startproject my_django[项目名称]

目录结构是这样

pycharm创建项目

安装完django后,new project可以看到django

建好之后的django是这样的目录结构

pycharm创建的django项目多了一个templates目录

目录结构分析

  • manage.py

一个类似于django-admin.exe的管理脚本,可以对你建立的django项目进行管理,每次新建一个django项目都会生成这个文件

  • init.py

一个空文件,标识这个文件夹是一个包

  • asgi.py

作为你的项目的运行在 ASGI 兼容的 Web 服务器上的入口,处理网络请求的文件

  • wsgi.py

作为你的项目的运行在 WSGI 兼容的Web服务器上的入口,也是处理网络请求的文件

  • settings.py

django项目的配置文件

  • urls.py

Django 项目的 URL 声明,就像你网站的“目录”,其实就是常说的路由配置

  • templates

模板文件放置的文件夹,html等等文件

启动web服务

python3 manage.py runserver

创建应用app

一个项目可以有很多应用,一个应用也可以被很多项目使用,应用app相当于一个功能模块

python3 manage.py startapp app1

目录结构如下

  • admin.py

django默认提供的后台管理,不需要修改

  • apps.py

一些关于创建的app的信息,不需要修改

  • models.py

数据库模型文件

  • views.py

视图文件,对web页面进行设计

  • migrations

数据库迁移文件,数据的每一次变更,这里就会记录

  • tests.py

测试文件

注册app

创建app后,要使用得先注册,找到settings.py,写入最后一行



这样就成功注册了app1这个应用,开始对app1进行开发

对app进行开发

先编写视图文件views.py

from django.shortcuts import render
from django.http import HttpResponse # Create your views here.
def index(request):
return HttpResponse("Hello World!")

一个经典的Hello world,这里是对http请求进行了处理,response返回一个Hello World!

在app1/ ,创建一个urls.py,默认是没有这个文件的,编写代码,把之前views编写的index函数给包含进去

from django.urls import path
from . import views urlpatterns = [
path('', views.index, name="index")
]

在my_django/urls.py继续编写,包含app1.urls

from django.contrib import admin
from django.urls import path, include urlpatterns = [
path('admin/', admin.site.urls),
path('app1/', include('app1.urls'))
]

启动web服务

python3 manage.py runserver,访问app1

数据库配置

默认数据库配置

django默认使用的是sqlite数据库,还是settings.py文件里看



如果想使用其它数据库,可以在这里进行修改

进行数据迁移应用

python3 manage.py migrate 对INSTALLED_APPS里注册的app进行一个迁移应用,每当注册了的app的数据发生迁移,都会进行一个记录

创建数据库模型

在这个投票应用中,需要创建两个模型:问题 Question 和选项 Choice。Question 模型包括问题描述和发布时间。Choice 模型有两个字段,选项描述和当前得票数。每个选项属于一个问题

编写app1/models.py

from django.db import models

# Create your models here.
class Question(models.Model):
question_text = models.CharField(max_length=200) # 创建一个字符串字段
pub_date = models.DateTimeField("date published") # 创建一个date字段 class Choice(models.Model):
question = models.ForeignKey(Question, on_delete=models.CASCADE) # 标识为外键
choice_text = models.CharField(max_length=200)
votes = models.IntegerField(default=0) # 创建一个数字型字段,默认值设为0

激活模型

python3 manage.py makemigrations app1,生成一个迁移

查看一下迁移所做的sql操作,python3 manage.py sqlmigrate app1 0001,可以看到已经帮我们创建了表



最后执行python3 manage.py migrate,应用一下所做的修改

这个 migrate 命令选中所有还没有执行过的迁移(Django 通过在数据库中创建一个特殊的表 django_migrations 来跟踪执行过哪些迁移)并应用在数据库上 - 也就是将你对模型的更改同步到数据库结构上。

API的使用

python3 manage.py shell,对刚才创建的模型进行一个使用



对模型文件进行一下修改,让Question.objects.all()所展示的信息更为直观

from django.db import models

# Create your models here.
class Question(models.Model):
def __str__(self):
return self.question_text
question_text = models.CharField(max_length=200) # 创建一个字符串字段
pub_date = models.DateTimeField("date published") # 创建一个date字段 class Choice(models.Model):
def __str__(self):
return self.choice_text
question = models.ForeignKey(Question, on_delete=models.CASCADE) # 标识为外键
choice_text = models.CharField(max_length=200)
votes = models.IntegerField(default=0) # 创建一个数字型字段,默认值设为0

管理员账户使用

创建一个管理员用户



账号 admin:admin123

创建之后访问/admin,登录进入后台

向管理页面加入投票应用

编写app1/admin.py

from django.contrib import admin
from .models import Question
# Register your models here.
admin.site.register(Question)

模板文件

模板文件的引用

在app1下创建一个templates文件夹,在该文件夹下继续创建一个index.html文件

{{question_text}}

编写views.py

from django.shortcuts import render
from django.http import HttpResponse
from django.template import loader # Create your views here.
def index(request):
template = loader.get_template("index.html")
context = {
"question_text": "123456"
}
return HttpResponse(template.render(context, request))

模板语法的使用

上面是一种最简单的变量引用方法

循环语句

<h1>
{% for i in n %}
<h2>{{i}}</h2>
{% endfor %}
</h1>
from django.shortcuts import render 
from django.http import HttpResponse
from django.template import loader # Create your views here.
def index(request):
n = ['f12', 'f13', 'f14']
return render(request, 'index.html', {'n': n})

条件语句

<h1>
{% if i == "f12" %}
<h2>f12 is handsome</h2>
{% else %}
<h2>f12 is very handsome</h2>
{% endif %}
</h1>
from django.shortcuts import render
from django.http import HttpResponse
from django.template import loader # Create your views here.
def index(request):
i = 'f12'
return render(request, 'index.html', {'i': i})

django的简单学习的更多相关文章

  1. django form使用学习记录

    Django forms使用容易, 又方便扩展, 因此Django admin和CBVs基本都基于forms使用. 事实上, 由于django forms的强大验证功能, 大多数Django API ...

  2. 沉淀,再出发:Django的简单使用

    沉淀,再出发:Django的简单使用 一.前言     在学习了python的基础语法之后,其实大家都很怀疑python的使用场景,其实python在很多场合都有很强的适应性,就比如说web开发之中使 ...

  3. Django 2.0 学习(07):Django 视图(进阶-续)

    接Django 2.0 学习(06):Django 视图(进阶),我们将聚焦在使用简单的表单进行处理和精简代码. 编写简单表单 我们将用下面的代码,来替换之前的detail模板("polls ...

  4. 基于Django进行简单的微信开发

    代码地址如下:http://www.demodashi.com/demo/11756.html 一.微信公众号的准备: 1. 注册 访问地址:https://mp.weixin.qq.com/ 按照提 ...

  5. django入门 -- 简单流程

    django入门 -- 简单流程 简介 通过简单示例,使用django完成基本流程的开发,学习django的主要的知识点,在后续课程中会逐个知识点进行深入讲解 以“图书-英雄”管理为示例 主要知识点介 ...

  6. Log4j简单学习笔记

    log4j结构图: 结构图展现出了log4j的主结构.logger:表示记录器,即数据来源:appender:输出源,即输出方式(如:控制台.文件...)layout:输出布局 Logger机滤器:常 ...

  7. Django - Django框架 简单介绍

    Django框架 简单介绍 本文地址: http://blog.csdn.net/caroline_wendy/article/details/29172271 1. 介绍 Django是一个开放源码 ...

  8. Python django实现简单的邮件系统发送邮件功能

    Python django实现简单的邮件系统发送邮件功能 本文实例讲述了Python django实现简单的邮件系统发送邮件功能. django邮件系统 Django发送邮件官方中文文档 总结如下: ...

  9. django的简单原理

    一.自定义客户端和服务端的请求响应 1.客户端打开url,向服务器发出请求 2.服务端用socket写一个py,用于接收请求和做出响应 3.服务端接收请求 4.服务端模拟HTTP协议做出响应,状态行为 ...

  10. shiro简单学习的简单总结

    权限和我有很大渊源. 培训时候的最后一个项目是OA,权限那块却不知如何入手,最后以不是我写的那个模块应付面试. 最开始的是使用session装载用户登录信息,使用简单权限拦截器做到权限控制,利用资源文 ...

随机推荐

  1. 数据库系列:MySQL InnoDB锁机制介绍

    数据库系列:MySQL慢查询分析和性能优化 数据库系列:MySQL索引优化总结(综合版) 数据库系列:高并发下的数据字段变更 数据库系列:覆盖索引和规避回表 数据库系列:数据库高可用及无损扩容 数据库 ...

  2. DES加密技术概述与应用

    一.引言 随着信息技术的飞速发展,数据安全已成为越来越受到重视的问题.数据加密技术作为保障信息安全的核心技术之一,得到了广泛的研究和应用.DES(Data Encryption Standard)作为 ...

  3. Python接口自动化项目----Anan

    优点 本效果展示仅是整体样式功能,更详细的使用方法和优点,需要参考使用手册. 整体的优点包括: 1.测试接口的统一管理 2.支持多环境 3.测试报告展示 4.定时任务 5.支持代码驱动 6.便捷的交互 ...

  4. net8获取泛微token以及访问api示例

    工作中涉及到调用泛微的场景,官方的示例又臭又长,抽空用NET8简化了写法,为了简化http访问,用了Flurl.Http这个库.在座各位大佬,我们直接就看代码了   using System.Secu ...

  5. 16、strconv

    1.strconv是什么? strconv是用来处理字符串和基本类型之间的转换的 2.strconv的使用 /** * @author ly (个人博客:https://www.cnblogs.com ...

  6. Git使用(GitEE)

    Git分布式版本控制工具 1. Git概述 1.1 Git历史 Git 诞生于一个极富纷争大举创新的年代.Linux 内核开源项目有着为数众多的参与者. 绝大多数的 Linux 内核维护工作都花在了提 ...

  7. SpringSecurity入门(SSM版)

    1. 简介 Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架.它提供了一组可以在Spring应用上下文中配置的Bean,充分利用了Sp ...

  8. Storm 集群的搭建及其Java编程进行简单统计计算

    一.Storm集群构建 编写storm 与 zookeeper的yml文件 storm yml文件的编写 具体如下: version: '2' services: zookeeper1: image: ...

  9. KNN算法实战——海伦约会(KDtree优化)

    本文通过海伦约会的例子来测试之前写的KDTree的效果,并且探讨了特征是否进行归一化对整个模型的表现的影响.最后发现在机器学习中,特征归一化确实对模型能提供非常大的帮助. 1 from KDTree ...

  10. 牛客小白月赛2 E题 是是非非 (尼姆博弈)

    题目链接:https://www.nowcoder.com/acm/contest/86/E 解题思路:由尼姆博弈我们可以知道,如果所有堆的石子数量异或为0,那么先手必败,否则先手必胜. 由异或我们可 ...