django学习总结1
## 内容回顾
#### 1.所有的命令
##### 下载安装
pip install django==1.11.20 - i 源
##### 创建项目
django-admin startproject 项目名
##### 启动项目
python manage.py runserver # 127.0.0.1:8000
python manage.py runserver 80 # 127.0.0.1:80
python manage.py runserver 0.0.0.0:80 # 0.0.0.0:80
##### 创建APP
Python manage.py startapp APP名称
##### 数据库迁移
python manage.py makemigrations # 根据models变化生成迁移文件
python manage.py migrate # 将变更记录同步到数据库
#### 2.配置
1. 静态文件
STAITC_URL = '/static/'
STATICFILES_DIRS = [
os.path.join(BASE_DIR,'static'),
]
2. INSTALLED_APPS = [
'app01' 或者 ‘app01.apps.App01Config’
]
3. 中间件
注释掉CSRF有关
4. DATABASES
ENGINE: mysql
NAME: 名字
HOST:IP
PORT: 端口
USER: 用户名
PASSWORD: 密码
5. TEMPLATES
DIRS :[ os.path.join(BASE_DIR ,'templates') ]
#### 3.django使用mysql数据库的流程:
1. 创建一个mysql数据库
2. 数据库的配置:
ENGINE: mysql
NAME: 名字
HOST:IP
PORT: 端口
USER: 用户名
PASSWORD: 密码
3. 告诉django使用pymysql连接mysql数据库
在与settings同级目录下的init。py写:
import pymysql
pymysql.install_as_MySQLdb()
4. 在app下的models中写类(表):
```python
from django.db import models
class Publisher(models.Model): # app01_publisher
pid = models.AutoField(primary_key=True)
name = models.CharField(max_length=32) # varchar(32)
class Book(models.Model):
name = models.CharField(max_length=32)
pub = models.ForeignKey('Publisher', on_delete=models.CASCADE)
class Author(models.Model):
name = models.CharField(max_length=32)
books = models.ManyToManyField('Book')
```
5. 执行数据库迁移的命令
python manage.py makemigrations # 根据models变化生成迁移文件
python manage.py migrate # 将变更记录同步到数据库
#### 4. request
request.method ——》 GET POST
request.GET ——》 url地址上的参数
request.POST ——》POST请求提交的数据
#### 5. response
HttpResponse("字符串") ——》 页面显示字符串
render(reqeust,'模板的文件名', { k1:v1 }) ——》 一个完整的页面#返回值key必须是字符串
redirect('要跳转的地址') ——》 重定向 Location: 要跳转的地址
#### 6.ORM
```python
from app01 import models
# 查
models.Publisher.objects.all() # 获取所有的数据 queryset 对象列表
models.Publisher.objects.filter(条件) # 获取所有满足条件的对象 queryset 对象列表
models.Publisher.objects.get(条件) # 获取一个满足条件的对象 对象 无或者多个就报错
models.Publisher.objects.all().order_by('pk') # 排序 升序
pub_obj.pid pub_obj.pk # 主键
pub_obj.name # 名字
book_obj.pk
book_obj.name
book_obj.pub ——》 书籍所关联的出版社的对象
book_obj.pub_id ——》 书籍所关联的出版社的对象pk
author_obj.books ——》 关系管理对象
author_obj.books.all() ——》 作者所关联的书籍对象
author_obj.books.set([ 所关联对象的id, 所关联对象的id,所关联对象的id ])
author_obj.books.set([ 所关联对象, 所关联对象,所关联对象 ])
# 增加
models.Publisher.objects.create(name='xxxx')
# 外键
models.Book.objects.create(name='xxxx',pub=pub_obj)
models.Book.objects.create(name='xxxx',pub_id=pub_obj.pk)
# 多对多
author_obj = models.Author.objects.create(name='xxxx')
author_obj.books.set([ id,id ])
obj = models.Publisher(name='xxxx')
obj.save()
# 删除
models.Publisher.objects.filter(pk=pk).delete()
models.Publisher.objects.get(pk=pk).delete()
# 修改
pub_obj.name ='new name'
pub_obj.save()
book_obj.name = 'new name'
book_obj.pub_id = pub_obj.id
book_obj.pub = pub_obj
book_obj.save()
author_obj.name = 'new name'
author_obj.save()
author_obj.books.set([id ,id])
```
#### 7.模板
{{ 变量 }}
正向查找
{{对象.找到自己和别人建的多对多的属性.all}}
反向查找
{{对象.找到别人和自己建的多对多的属性_set.all}}
```html
{% for i in list %}
{{ forloop.counter }}
{{ i }}
{% endfor %}
{% if 条件 %}
xxx
{% elif 条件 %}
xxxx
{% else %}
xx
{% endif %}
```
## 今日内容
#### 1. MVC MTV
MVC
- M models
- V view HTML
- C controller 控制器
MTV
- M models
- T template HTML
- V view 函数 业务逻辑
#### 2. 过滤器
语法
{{ value|filter_name }} {{ value|filter_name:参数 }}
**default**
```
{{ value|default:"nothing"}}
```
**add**
数字加减
字符串的拼接
列表的拼接
```
{{ value|add:"2" }}
```
**length**
取变量的长度
**slice**
切片
**truncatechars**
截断字符
**date**
```
{{ value|date:"Y-m-d H:i:s"}}
```
```
# settings 中配置
USE_L10N = False
DATETIME_FORMAT = 'Y-m-d H:i:s'
```
**safe**
Django这段代码是安全的不必转义
https://docs.djangoproject.com/en/1.11/ref/templates/builtins/#built-in-filter-reference
自定义filter
1. 在app下创建一个名为templatetags的Python包 # templatetags不能变
2. 在包内创建py文件 —— my_tags.py
3. 在py文件中下:
```python
from django import template
register = template.Library() # register 不能变
```
4. 写函数+装饰器
```python
@register.filter
def add_str(value, arg=None): # 函数名 就是 过滤器的名字 value变量 arg 给变量添加额外的参数
ret = '{}__{} '.format(value, arg)
print(ret)
return ret
```
5.使用自定义装饰器:
```
{% load my_tags %} # 导入文件
{{ 'alex'|add_str:'sb' }}
```
6.如何让用装饰器实现html语言
```HTML
使用
{{ 'https://www.baidu.com'|show_a:'百度'|safe }}
```
还可以引入
from django.utils.safestring import mark_safe
return mark_safe(obj)
就可以了
django学习总结1的更多相关文章
- 今天主要推荐一下django学习的网址!
前言:每个月忙碌的头20天后,在上班时间投入到django理论学习的过程中,花了差不多3天时间简单的研究了一下django,着实废了我不少脑细胞. 采用虫师前辈的一张图和话: 如果你把这过程梳理清晰了 ...
- Django 学习笔记之四 QuerySet常用方法
QuerySet是一个可遍历结构,它本质上是一个给定的模型的对象列表,是有序的. 1.建立模型: 2.数据文件(test.txt) 3.文件数据入库(默认的sqlite3) 入库之前执行 数据库同步命 ...
- Django 学习笔记之三 数据库输入数据
假设建立了django_blog项目,建立blog的app ,在models.py里面增加了Blog类,同步数据库,并且建立了对应的表.具体的参照Django 学习笔记之二的相关命令. 那么这篇主要介 ...
- Django学习系列之Form基础
Django学习系列之Form基础 2015-05-15 07:14:57 标签:form django 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追 ...
- Django学习笔记(五)—— 表单
疯狂的暑假学习之 Django学习笔记(五)-- 表单 參考:<The Django Book> 第7章 1. HttpRequest对象的信息 request.path ...
- Django学习笔记(三)—— 型号 model
疯狂暑期学习 Django学习笔记(三)-- 型号 model 參考:<The Django Book> 第5章 1.setting.py 配置 DATABASES = { 'defaul ...
- django学习之Model(二)
继续(一)的内容: 1-跨文件的Models 在文件头部import进来,然后用ForeignKey关联上: from django.db import models from geography.m ...
- Python框架之Django学习
当前标签: Django Python框架之Django学习笔记(十四) 尛鱼 2014-10-12 13:55 阅读:173 评论:0 Python框架之Django学习笔记(十三) 尛 ...
- Django 学习笔记(二)
Django 第一个 Hello World 项目 经过上一篇的安装,我们已经拥有了Django 框架 1.选择项目默认存放的地址 默认地址是C:\Users\Lee,也就是进入cmd控制台的地址,创 ...
- Django 学习笔记(五)模板标签
关于Django模板标签官方网址https://docs.djangoproject.com/en/1.11/ref/templates/builtins/ 1.IF标签 Hello World/vi ...
随机推荐
- 【LeetCode】869. Reordered Power of 2 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 字典统计每位数字出现的次数 日期 题目地址:http ...
- 【LeetCode】117. Populating Next Right Pointers in Each Node II 解题报告(Python)
[LeetCode]117. Populating Next Right Pointers in Each Node II 解题报告(Python) 标签: LeetCode 题目地址:https:/ ...
- .NET Core 实现动态代理做AOP(面向切面编程)
1.介绍 1.1 动态代理作用 用动态代理可以做AOP(面向切面编程),进行无入侵式实现自己的扩展业务,调用者和被调用者之间的解耦,提高代码的灵活性和可扩展性,比如:日志记录.性能统计.安全控制.事务 ...
- Laravel 使用 maatwebsite/Excel 3.1 实现导入导出的简单方法
官方文档 https://docs.laravel-excel.com/3.1/getting-started git地址 https://github.com/maatwebsite/Laravel ...
- Deep Linear Networks with Arbitrary Loss: All Local Minima Are Global
目录 问题 假设和重要结果 证明 注 Laurent T, Von Brecht J H. Deep linear networks with arbitrary loss: All local mi ...
- Linux配置yum源(离线和在线)
配置yum源有2种方法,一种是离线yum源,另外一种是在线yum源. 一.离线yum源,基于安装光盘提供的安装仓库. 建立一个属于仓库文件夹 mkdir /media/zidong cd /media ...
- PDF的信息提取的问题
PDF对企业应用来说是刚需. 然而PDF显然不是一种对机器友好的格式,它只是对人类友好,就是说方便阅读打印,但让程序去提取其中的内容却很难.下面简单说说为什么是这样. 以前还读书的时候(20+ ...
- Pytest_定制allure报告(12)
定制报告需要先导入allure模块,再使用以下装饰器方法: feature: 标注主要功能模块. story: 标注feature功能模块下的分支功能. description:在报告中显示用例描述. ...
- spring cloud --- Feign --- 心得
spring boot 1.5.9.RELEASE spring cloud Dalston.SR1 1.前言 什么是Feign? 为了简化我们的开发,Spring Cloud Fei ...
- 闯祸了,生成环境执行了DDL操作《死磕MySQL系列 十四》
由于业务随着时间不停的改变,起初的表结构设计已经满足不了如今的需求,这时你是不是想那就加字段呗!加字段也是个艺术活,接下来由本文的主人咔咔给你吹. 试想一下这个场景 事务A在执行一个非常大的查询 事务 ...