Django的基础操作总结
1:准备开始
建立一个新的project: django-admin.py startproject XXXXXX(名称)
建立一个新的App:python manage.py startapp XXXXX(名称)
将app响应:打开project文件下的seettings,找到INSTALLED_APPS ,填写app名字
MTV模式:models:业务对象和数据库关系
Views:业务逻辑
Templates:页面展示
Django如何运行:请求-中间件-url分发器-处理http请求-调用数据模型-模板展示界面-返回一个http响应-发送给客户端
Django mtv的设计模式优点:组件松懈,目的明确,不相互影响。
同步数据库:python manage.py makemigrations
python manage.py migrate
创建管理员:python manage.py createsuperuser
2:开发开始:
1:建立App后所需要的另建的文件夹:Static:存放静动态文件
Templates:存放模板
2:Static,temelates存放位置:App文件根目录
3:修改默认的Static,templates文件夹路径:
修改模板文件夹:在project文件夹下找到seettings,找到Templates项,在‘DIRS’处填写templates的路径
修改静态文件夹:在project文件夹下找到seettings,新建’STATICFILES_DIRS‘项,
写法如下:
STATICFILES_DIRS = (os.path.join(BASE_DIR,’STATIC’)#STATIC是路径
4:多个App下,定义不同的urls.py:
写法:
项目urls.py:
import include
Urlpatterns = [Url(r’^’,include(‘XXX.urls’))(app名)]
App urls.py:
Urlpatterns = [Url(r’^’,views.XXX(app名)]
5:urls.py相关知识:
Urls.py被称为路由配置文件,就是一个调用视图函数的映射。
Urlpatterns配置形式:
无前缀,使用列表配置:Urlpatterns = [Url(r’^’,views.XXX(app名)]
基本模式:Urlpatterns = [url(正则表达式,view,参数,别名,前缀)]
Url常用写法:
url(r’^text/ \d{2} / $’,views.test):定义一个test开头的后接两位数字的网址
Example:http://127.0.0.1:8080/test/21/
6:HttpRequest相关属性:
Path:请求页面全路经:print(request.path)#返回请求路径
Method:请求使用的HTTP方法的字符串表示:if request.methoid == ‘GET’ or ‘POST’d
GET:GET参数
POST:POST参数
REQUEST:POST和GET属性的集合体,优先度上有差异,先查找POST,再查找GET
User:代表当前登陆的用户,django.contrib.models.User对象,通过User的 is_authenticated()判断是否登陆:if request.user.is_authenticated():
Session:可读写属性,代表当前会话的字典对象
7:HttpResponse:
HTTPResponse必须自己创建,每个view请求处理的方法必须返回一个Response值。
8:Django数据库的配置:
Django支持sqlite,mysql,oracle,等第三方数据库
9:数据库引擎:
Sqlite:django.db.backends.sqlite3
Mysql: django.db.backends.mysql
10:切换mysql数据库:
进入seetings,database 处 ,填写
'ENGINE': 'django.db.backends.mysql',
'NAME': 'test_db',
'USER': 'lau',
'PASSWORD':'',
进入__init__处,填写
import pymysql
pymysql.install_as_MySQLdb()
更新数据库操作。
11:orm机制:
Object Relational Mapping的简称,用面向对象的方式去操作数据库的操作,例如创建表,增加,修改,查询等操作。
12:models.py的定义:
首先必须确定models的基本结构
每个模型相当于单个数据表
例如,一个数据库,里面的元素有员工,工作类型,工作名称,员工地址,所在城市这几项。
确定元素的关系(一对一,一对多):工作类型-员工(一对多)
模型之间的三种关系(一对一,OneToOneField),(一对多,ForeginKey),(多对多,ManyToMany)
模型常用的字段:
1:BoleanField(布尔) 2: CharField(字符串) 3: DateField(日期)
4:DateTimeField(日期时间)5:DecimalField(小数字段)6:IPAddressField(IP)
7:ImageField(图片)8:TextField(文本)9:URLField(网页地址)
确定元素的字段:员工(性别,年龄)
编写代码:
from django.db import models
class Publiser(models.Model):
company_name = models.CharField(max_length=30)#定义一个‘公司名’的字段,最大长度30
company_address = models.CharField(max_length=60)
company_city = models.CharField(max_length=50)
company_web = models.URLField()#定义一个URL类型字段
class Human(models.Model):
name = models.CharField(max_length=30)import pymysql_x000B_pymysql.install_as_MySQLdb() class HumanDetail(models.Model):
sex = models.BooleanField(max_length=1,choices=(('','男'),('','女'),))#定义一个布尔类型字段
email = models.EmailField() #定义一个email字段
address = models.CharField(max_length=50)
birthady = models.DateField()
human = models.OneToOneField(Human)
class Work(models.Model):
Work_name = models.CharField(max_length=100)
Work_human = models.ManyToManyField(Human)
Work_company = models.ForeignKey(Publiser)
Work_date = models.DateField()
编写上述代码后,在admin.py中编写如下代码,将信息注册至后台
from .models import *
admin.site.register(Publiser)
admin.site.register(Human)
admin.site.register(HumanDetail)
admin.site.register(Work)
13:数据模块的扩展属性:
Example(1):如果想要显示一个中文名称,如何去做?Verbose_name = “”
class Human(models.Model):
name = models.CharField(max_length=30)
class Meta:
verbose_name = '姓名'
verbose_name_plural = verbose_name
14:定义一个模型的方法:
Example(1):在、改变显示的project的名字,让它显示中文,如何去做?def __str__(self),python2:def _unicode_()
class Human(models.Model):
name = models.CharField(max_length=30)
class Meta:
verbose_name = '姓名'
verbose_name_plural = verbose_name
def __str__(self):
return self.name
15:模型常用的字段选项:
null(null=True|False):数据库字段设置是否可以为空
blank(balnk=True|False):表单验证字段是否为空
choices:轻量级配置字段可选属性
default: 字段默认值
15:模型的扩展属性:
什么是扩展属性?排序字段,设置名称等
如何设置?通过内部类Meta设置扩展属性
例:改变Model显示的名称,并且修改名称使不为复数状态,排序字段,降序
class Meta:
verbose_name = '公司信息'
verbose_name_plural = verbose_name
Ordering = [‘排序字段’]
16:migrations文件夹是做什么的?
用来存放通过makemigrations命令生成的数据库脚本,app目录下必须要有该目录,并且要有__init__.py才能使用数据库同步功能
17:orm的常用操作:
往表里添加数据:
利用shell方法:python manage.py shell
create添加操作:(create和save)
Human.objects.create(name=’大刘’)#在Human表里添加名为‘大刘’的数据
Object:是model的默认管理器,create是管理器的方法
save插入信息: pub = Publiser() / pub.company_name = ‘233’ / pub.save()
主外键关系处理:关联id方式:human_id = 1
多对多关系处理: human = Human.objects.get(id=23)
work = Work.objects.get(id=1)
human.Work_human.add(work)
修改某数值:一般套路:(1)先获取,再修改。
例子:修改id为1的名字为江蛤:
(1)获取:human = Human.objects.get(id=1)
(2)修改:human.name = '江蛤'
(3)写入:human.save()
特殊套路:(一步到位fliter update):多对多关系处理
例子:修改id为2的城市名为成都
(1)Publiser.objects.filter(id=2).update(company_city='成都')
查询数值:(堕性查询)
查询human下全部数值:human.object.all()
Queryset特点:可迭代,可切片
QuerySet常用的API
Get:返回所给的筛选条件相匹配的对象,结果有且只有一个,如果超过一个抛出异常Mulitpe,没有结果抛出DoesNot
all:返回查询所有结果。
order_by:查询结果排序
reverse:反向排序
distinct:返回结果剔除重复记录
values:返回一个可迭代的字典序列
filter:包含条件筛选查询匹配对象
execude:包含条件筛选查询不匹配对象
count:返回匹配查询的对象数量
first:返回第一条记录
last:返回最后一条记录
exists:如果包含数据,返回True,反之,返回False
多表查询:
例子:
查询所有作者的信息:作者名字在作者表中,作者信息在作者详情表中,有一个外键对应作者表
调用方法:authorDetail.obejcts.value(‘author__name’,’address’):双下划线调用
聚合查询和分组查询:
如何判断使用何种查询:
查询某某作者书价格总数:使用聚合查询:
Publisher.objects.values(‘author_name’).annote(Sum(‘price’))
查询每个作者书价格总数:使用分组查询:
From django.db.models import *
Publisher.objects.fileter(name=’XXX’).aggregate(count())
annote:用于用于分组查询,计算总值
aggregate:用于聚集查询,返回一个聚合值的字典
聚合函数:
Avg:平均值
Count:返回被关联的数量
Max:最小值
Min:最大值
Sum:总和
如何使用原生Sql:
模板标签和逻辑控制:
(1)模板的组成:html + 逻辑控制代码
(2)逻辑控制代码组成:变量(双大括号{{ 变量 }},view传递而来)
标签 (单大括号,百分号{% 标签 %}
过滤器 {{变量 | 过滤器:”参数”}}
(3)常用标签:{% if %}:and of not 可以组织逻辑,搭配{% elif %}
{% ifequal %}:搭配{% ifnotequal %},比较是否相等
{% for %}:循环一个list
{% cycle %}:循环时轮流使用给定的字符串列表的值
{##},{% comment %}:注释
{% csrf_token %}:生成csrf_token标签,防止跨站攻击
{% debug %}:调试
{% autoescape %}:自动转义设置
{% firstof %}:输出一个值不等于False的变量
{% load %}:加载标签库
{% now %}:获取当前时间
{% spaceless %}:移除空格
{% url %}:引入路由地址
{% verbatim %}:禁止render
{% with %}:简单变量名缓存复杂变量名
模板的包含与继承:
包含:
示例:在templates文件夹下新建一个html文件,将html文件中的内容添加到主html中
使用{% include ‘新文件名.html’ %}添加到主文件html任何地方
路径导入:{% include ‘文件夹名/新文件名.html’ %}
继承:先构造一个基础模板,然后在子模板处对它所包含站点共用部分和定义重载。
示例:{% block %} : 定义块
{% entend %} : 继承父模板
Form知识点:
主要用于表单系统,所有表单类都作为django.forms.Form的子类
表单系统分两种,基于django.form.Form:所有表单的父亲
基于django.forms.ModelForm:模型类绑定
Django的基础操作总结的更多相关文章
- Python学习---Django的基础操作180116
Django创建数据库操作 django流程之model实例 settigs.py:更改Django2.0.1的配置,更新为之前的路径配置 'DIRS': [os.path.join(BASE_DIR ...
- Django Model基础操作
关于设计django model django为我们集成了ORM对数据库进行操作,我们只需要进行定义model,django就会自动为我们创建表,以及表之间的关联关系 创建好一个django项目-首先 ...
- Django开发基础----操作数据库
Django中对数据库的操作是由Models来完成的 Models是什么? 通常,一个Model对应数据库的一张数据表 Django中Models以类的形式出现 它包含了一些基本字段以及数据的一些行为 ...
- Django 08 Django模型基础3(关系表的数据操作、表关联对象的访问、多表查询、聚合、分组、F、Q查询)
Django 08 Django模型基础3(关系表的数据操作.表关联对象的访问.多表查询.聚合.分组.F.Q查询) 一.关系表的数据操作 #为了能方便学习,我们进入项目的idle中去执行我们的操作,通 ...
- Django笔记&教程 6-2 表单(Form)基础操作
Django 自学笔记兼学习教程第6章第2节--表单(Form)基础操作 点击查看教程总目录 1 - 编写表单类 创建新的表单类的代码,一般写到一个专门的forms.py文件中(一般放在对应的app文 ...
- Python之路【第十六篇】:Django【基础篇】
Python之路[第十六篇]:Django[基础篇] Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...
- SLAM+语音机器人DIY系列:(一)Linux基础——3.Linux命令行基础操作
摘要 由于机器人SLAM.自动导航.语音交互这一系列算法都在机器人操作系统ROS中有很好的支持,所以后续的章节中都会使用ROS来组织构建代码:而ROS又是安装在Linux发行版ubuntu系统之上的, ...
- 【Python全栈-后端开发】Django入门基础-2
Django入门基础知识-2 一 .模版 一.模版的组成 HTML代码+逻辑控制代码 二.逻辑控制代码的组成 1 变量(使用双大括号来引用变量) {{var_name}} 2 标签(tag)的使用 ...
- Django中-事务操作
如何在Django中进行事务操作呢? 近期,公司里要使用Django开发一套金融相关的系统. 涉及钱了.....安全安全安全 如果钱转到一半,系统崩了,咋办? 如果钱汇到一半,系统崩了,咋办? 如果东 ...
随机推荐
- Python模拟浏览器上传文件脚本(Multipart/form-data格式)
http协议本身的原始方法不支持multipart/form-data请求,这个请求由原始方法演变而来的. multipart/form-data的基础方法是post,也就是说是由post方法来组合实 ...
- ADO.NET:连接数据字符串
ylbtech-ADO.NET:ADO.NET-Oracle|SQLServer|MySql|Access|Excel-dddd ADO.NET:连接数据字符串 1.A,SqlServer返回顶部 1 ...
- 【GLSL教程】(一)图形流水线 【转】
http://blog.csdn.net/racehorse/article/details/6593719 这是一些列来自lighthouse3d的GLSL教程,非常适合入门.我将边学习边翻译该教程 ...
- SSD配置
SSD: Single Shot MultiBox Detector - 运行“ make -j32”时出错: nvcc warning : The 'compute_20', 'sm_20', an ...
- Could not open lock file/var/lib/dpkg/lock
apt-get时出现错误提示: E: Could not get lock /var/lib/dpkg/lock - open (11: Resource temporarily unavailabl ...
- Spring boot Security Disable security
When I use security.basic.enabled=false to disable security on a Spring Boot project that has the fo ...
- 移动端弹窗 layer.js 使用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- TCP/IP详解 卷一(第四、五章 ARP、RARP)
数据链路如 以太网都有自己的寻址机制(MAC)地址,而IP层使用的是IP地址. 当一台主机把以太网数据发送定位于同一局域网上的另一台主机时,是根据MAC地址来确定目的接口的.设备驱动程序从不检查IP数 ...
- java个人感想
java与c++相比,摒弃了c++的指针,把c++中的stl封装成一个库,而且改变了当中的某些方法,使用方法也产生了非常多不同,读者在编程过程中须要自己细细体会 个人觉得三大框架基于前端+领域逻辑+数 ...
- ThinkPHP中的模型命名
当我们创建一个UserModel类的时候,其实已经遵循了系统的约定.ThinkPHP要求数据库的表名和模型类的命名遵循一定的规范,首先数据库的表名和字段全部采用小写形式,模型类的命名规则是除去表前缀的 ...