Django项目的创建与介绍.应用的创建与介绍.启动项目.pycharm创建启动项目.生命周期.三件套.静态文件.请求及数据.配置Mysql完成数据迁移.单表ORM记录的增删改查
一、Django项目的创建与介绍
'''
安装Django
#在cmd中输入pip3
#出现这个错误Fatal error in launcher: Unable to create process using '"'
#可以直接用 python3 -m pip 代替 pip3
#这个问题是pip3 版本过低直接在cmd中执行 python3 -m pip install --upgrade pip 更新pip3 # 在指定解释器环境下安装django 1.11.9
# 在真实python3环境下: pip3 install django==1.11.9 # 查看django版本: django-admin --version
# 安装出错: 采用管理员命令行
'''
'''
创建项目
# 先前往目标路径
在cmd
C:\Users\Administrator>E:
E:\>cd E:\python-li\Django
# 创建项目: django-admin startproject proj_name
E:\python-li\Django>django-admin startproject dg01 proj_name:项目目录,包含项目最基本的一些配置
-- __init__.py:模块的配置文件
-- settings.py:配置总文件
-- urls.py:url配置文件,django项目中的所有页面都需要对其配置url地址
-- wsgi.py:(web server gateway interface),服务器网关接口,python应用与web服务器直接通信的接口
templates:模板文件夹,存放html文件的(页面),支持使用Django模板语言(DTL),也可以使用第三方(jinja2)
manage.py:项目管理器,与项目交互的命令行工具集的入口,查看支持的所有命令python3 manage.py
'''
二、应用的创建与介绍
'''
1.Django是面向应用开发,在应用中完成具体的业务逻辑
2.什么是应用app: 就好比项目中的一个功能模块,一个项目可以拥有多个功能模块,但至少得有一个,Django称之为app
3.如何创建app(在项目目录下):
# 进入项目根目录
E:\python-li\Django>cd dg01
# 创建应用: python3 manage.py startapp app_name
E:\python-li\Django\dg01>python3 manage.py startapp app01 migrations:数据迁移(移植)模块,内容都是由Django自动生成
-- __init__.py
__init__.py
admin.py:应用的后台管理系统配置
apps.py:django 1.9后,本应用的相关配置
models.py:数据模型模块,使用ORM框架,类似于MVC模式下的Model层
tests.py:自动化测试模块,可以写自动化测试脚本
views.py:执行相应的逻辑代码模块
'''
三、启动项目
'''
#在项目目录下执行
# 终端: python3 manage.py runserver
E:\python-li\Django\dg01>python3 manage.py runserver
#默认127.0.0.1:8801
'''
四、pycharm创建启动项目
'''
1.创建Django
2.选择项目目录(从项目目录开始,目录文件夹及子文件夹不要出现中文,保证电脑名字不能为中文)
3.配置默认模板语言,模板路径,app名
4.启动
'''
五、生命周期
'''
1.浏览器发送请求
2.wsgi服务器接收到请求,将请求解析交给Django
3.Django中间件过滤请求信息,交给路由
4.路由完成业务逻辑的分发,到指定app下views中指定的视图函数
在views的指定视图函数必须接受一个参数,我们将其命名为request
可以用request.method得到请求方法
5.视图函数完成具体的业务逻辑,返回响应结果
响应文件回去我们应该将文件放到templates这个文件夹下
6.将处理结果通过服务器返回给浏览器
'''
六、三件套
#views中返回响应结果三件套
from django.shortcuts import HttpResponse, render, redirect def action1(request):
#返回普通字符串
return HttpResponse("基础信息") def action2(request):
#返回页面 (request,返回页面名,字典)
return render(request, 'template_page.html', {k:v}) def action3(request):
#重定向 ('/重定向到的请求/')
return redirect('/index/')
七、静态文件
'''
1.在settings.py中配置
STATIC_URL = '/static/' # 静态文件请求根路由
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static') # 静态文件检索的文件夹
]
2.在项目根目录下创建static文件夹
3.静态文件就放在static根目录或子目录下
4.获取静态文件:/static/目标文件(可以包含static子文件夹路径)
如:/static/my.css
/static/css/my.css
'''
八、请求及数据
'''
请求路径 form表单中的action:
1.空着:默认向当前路径发送请求
2.http://127.0.0.1:8801/testAction/:向testAction路径发送请求
3./testAction/: 向testAction路径发送请求(推荐)
小知识点:①可以在settings.py下的中间件配置中找到含有csrf的那条代码,将它关闭这样就可以跳过post请求的安全认证
②print(type(request)) 得到一行代码,直接import点击进入可以查看request源码 在视图函数中
请求方式:request.method
GET请求获取数据:request.GET.get('key', None) # 当key不存在,用None替换
POST请求获取数据:request.POST.get('key', None) # 当key不存在,用None替换
'''
九、配置Mysql完成数据迁移
'''
1.在settings.py配置Mysql数据库信息
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'dg2',
'HOST': '127.0.0.1',
'PORT': 3306,
'USER': 'root',
'PASSWORD': 'root'
}
} 2.在项目或应用的init文件中修改连接数据库的模块为pymysql (python3后连接数据库采用pymysql来代替MYSQLdb) import pymysql
pymysql.install_as_MySQLdb() 3.在项目目录下(可以在cmd中执行,也可以直接在pycharm中执行dg文件然后在显示台terminal中执行),执行(生成迁移数据,没有映射到数据库):python3 manage.py makemigrations
#E:\python-li\Django\dg2>python3 manage.py makemigrations 4.将迁移数据映射到数据库:python3 manage.py migrate
#E:\python-li\Django\dg2>python3 manage.py migrate
#建成的表名:应用名_表名 3,4可以有个简单方法 在pythorm上方的Tools执行Run manage,py Task
在命令行直接运行makemigrations 然后运行migrate ''
十、单表ORM记录的增删改查
'''
Django所有的增删改查都封装到model中去了,直接用User.objects调用方法
filter()方法是过滤,中间写过滤的条件
# 增
User.objects.create(usr='abc', pwd='123') # 第一种方式
user = User(usr='owen', pwd='123')
user.save() # 第二种方式
# 删
User.objects.filter(id=1).delete()
# 改
User.objects.filter(pwd='123').update(pwd='000')
# 查
User.objects.all()
User.objects.filter(pwd='000').all()
User.objects.filter(pwd='000').first()
'''
Django项目的创建与介绍.应用的创建与介绍.启动项目.pycharm创建启动项目.生命周期.三件套.静态文件.请求及数据.配置Mysql完成数据迁移.单表ORM记录的增删改查的更多相关文章
- mysql对库,表及记录的增删改查
破解密码 #1.关闭mysqlnet stop mysqlmysql还在运行时需要输入命令关闭,也可以手动去服务关闭 #2.重新启动mysqld --skip-grant-tables跳过权限 #3m ...
- hibernate课程 初探单表映射3-5 hibernate增删改查
本节简介: 1 增删改查写法 2 查询load和查询get方法的区别 3 demo 1 增删改查写法 增加 session.save() 修改 session.update() 删除 session. ...
- MySQL数据库初识、下载使用(针对库、表、记录的增删改查)
今日内容概要 数据演变史 数据库软件的本质 MySQL简介 下载与安装 基本配置 基本SQL语句 内容详细 1.数据演变史 # 1.单独的文本文件 没有固定的存放位置和格式 文件名:user.txt ...
- Mysql数据库文件、表、记录的增删改查
一.数据库文件夹的的操作 create database db1 charset utf8; 增加db1文件夹 show databases ; 查看所有数据库 show create databas ...
- Django ORM记录的增删改查结合web端
模版语法分配变量 在views.py文件中定义一个视图函数show_data: def show_data(request): # 定义一个字典 并将它展示在前端HTML文件 user_dic = { ...
- [Django框架 - 静态文件配置、request对象方法初识、 pycharm链接数据库、ORM实操增删改查、django请求生命周期]
[Django框架 - 静态文件配置.request对象方法初识. pycharm链接数据库.ORM实操增删改查.django请求生命周期] 我们将html文件默认都放在templates文件夹下 将 ...
- 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- 五 Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- 一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器
一.数据库表中字段的增删改查 ''' 直接在modules中对字段进行增删改查 然后在tools下点击Run manage.py Task执行makemigrations和migrate 注意在执行字 ...
随机推荐
- Dapper基础入门
Dapper是一个轻量级的ORM.之前最常用的ORM是EF,其实EF底层是Ado.net实现的. 现在基本上已经远离SqlHelper时代了. Dapper是开源的 https://github.c ...
- @AfterThrowing
@AfterThrowing(throwing="ex", pointcut="within(com.xms.controller.*)") public vo ...
- 实时计算DStream下求平均值(reduceByKey or combineByKey)
对NC市的卡口数据进行分析,大概所有卡口每15秒接入的有效数据在3000条左右,现在产品经理要求对这些数据进行拥堵分析,通过两个卡口之间的车辆行驶时长来判断道路的拥堵情况.具体算法不展开.其中我需要做 ...
- LeetCode160.相交链表
编写一个程序,找到两个单链表相交的起始节点. 例如,下面的两个链表: A: a1 → a2 ↘ c1 → c2 → c3 ↗ B: b1 → b2 → b3 在节点 c1 开始相交. 注意: 如果两个 ...
- django-pagination配置出错处理
是否有人出现这类错误: 首先确认几个修改处: setting.py添加 INSTALLED_APPS = ( # ... 'pagination', ) 添加中间件 MIDDLEWARE_CLASSE ...
- pyinstaller将python脚本生成exe
一.下载pyinstaller 二.生成exe 下载pyinstaller 1.在C:\python27\Scripts目录下打开cmd界面,执行命令:pip install PyInstaller ...
- 最近点对HDU1007
利用二分的方法来计算,应该是说利用分治的方法吧! 刚开始感觉时间会爆 后来发现嘎嘎居然没有 ,嗨自己算错了时间: #include <iostream> #include<cstdi ...
- Python大神成长之路: 第三次学习记录 集合 函数 装饰 re
学习记录day03 字符串可以直接切片,But字符串不可修改 字符串修改:生成了一个新的字符串 LIst修改,在原基础上修改(原内存上) 集合是一个无序的,不重复的数据组合,它的主要作用如 ...
- Spark学习之路 (十六)SparkCore的源码解读(二)spark-submit提交脚本
一.概述 上一篇主要是介绍了spark启动的一些脚本,这篇主要分析一下Spark源码中提交任务脚本的处理逻辑,从spark-submit一步步深入进去看看任务提交的整体流程,首先看一下整体的流程概要图 ...
- 大数据处理框架之Strom:Storm集群环境搭建
搭建环境 Red Hat Enterprise Linux Server release 7.3 (Maipo) zookeeper-3.4.11 jdk1.7.0_80 Pyth ...