饮冰三年-人工智能-Python-22 Python初识Django
1:一个简单的web框架
# 导包
from wsgiref.simple_server import make_server
#自定义个处理函数
def application(environ,start_response):
start_response("200 OK",[('Content-Type','text/html')])
return [b'<h1>Hello,web!</h1>'] httpd = make_server('',8091,application)
print('Serving HTTP on port 8091....')
httpd.serve_forever()
HelloWorld

# 导包
from wsgiref.simple_server import make_server
#自定义个处理函数
def application(environ,start_response):
# 获取路径
path = environ["PATH_INFO"]
start_response("200 OK",[('Content-Type','text/html')])
if path=="/yang":
return [b'<h1>Hello,yang!</h1>']
elif path=="/Aaron":
return [b'<h1>Hello,aaron!</h1>']
else:
return [b'<h1>404!</h1>'] httpd = make_server('',8091,application)
print('Serving HTTP on port 8091....')
httpd.serve_forever()
2.0

# 导包
from wsgiref.simple_server import make_server def yang():
f=open("yang.html","rb")
data=f.read()
return data
def aaron():
f=open("aaron.html","rb")
data=f.read()
return data
#自定义个处理函数
def application(environ,start_response):
# 获取路径
path = environ["PATH_INFO"]
start_response("200 OK",[('Content-Type','text/html')])
if path=="/yang":
return [yang()]
elif path=="/Aaron":
return [aaron()]
else:
return [b'<h1>404!</h1>'] httpd = make_server('',8091,application)
print('Serving HTTP on port 8091....')
httpd.serve_forever()
调用HTML内容

# 导包
import time
from wsgiref.simple_server import make_server def region(req):
pass;
def login(req):
print(req["QUERY_STRING"])
f=open("login.html",'rb')
data=f.read();
return data;
def yang(req):
f=open("yang.html","rb")
data=f.read()
return data
def aaron(req):
f=open("aaron.html","rb")
data=f.read()
return data
def show_time(req):
times=time.ctime()
# 方法一:通过模板使用
# con=("<h1>time:%s</h1>" %str(times)).encode("utf8")
# return con
# 方法二:字符串替换
f = open("show_time.html", "rb")
data = f.read()
data=data.decode("utf8")
data =data.replace("{{time}}",str(times))
return data.encode("utf8")
# 定义路由
def router():
url_patterns=[
("/login",login),
("/region", region),
("/yang", yang),
("/aaron", aaron),
("/show_time",show_time),
] return url_patterns
#自定义个处理函数
def application(environ,start_response):
# 获取路径
path = environ["PATH_INFO"]
start_response("200 OK",[('Content-Type','text/html')])
url_patterns = router()
func =None
for item in url_patterns:
if item[0]==path:
func=item[1]
break
if func:
return [func(environ)]
else:
return [b'']
httpd = make_server('',8091,application)
print('Serving HTTP on port 8091....')
httpd.serve_forever()
模拟路由
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
*{
margin: 0;
padding: 0;
}
</style>
</head>
<body>
<h1>时间:{{time}}}</h1>
</body>
</html>
show_time.html

2:一个简单的django案例
Django的下载与安装


如何检验是否安装成功?

2.1 创建django项目的两种方法
--创建Django项目
django-admin startproject mysite --创建应用
python manage.py startapp blog
通过命令创建


方式2:通过Pycharm创建

创建成功

大致分为三步
a:修改urls.py 类似控制器,把想要展示的内容通过地址配置一下

b:在views中设置具体的逻辑

c:在templates中设置要显示的页面内容

通过命令行启动django。
python manage.py runserver 8091

如何引用js
a:添加static文件,并把js放置到该文件下

b:在setting文件中配置

c:在对应的文件中做引用


3:URL配置(URLconf):又叫做路由系统,其本质是提供路径和视图函数之间的调用映射表。
格式:
urlpatterns=[
url(正在表达式,views视图函数,参数,别名)
]
例1:匹配 XXX/articles/年份(只能匹配4位数字)
from django.contrib import admin
from django.urls import path
from django.conf.urls import url
from blog import views
urlpatterns = [
path('admin/', admin.site.urls),
path('show_time/',views.show_time),
url(r'^articles/[0-9]{4}/$', views.year_archive), ]
urls.py--1.0
from django.shortcuts import render,HttpResponse
import time
def show_time(request):
# return HttpResponse("Hello")
return render(request,"index.html",{"time":time.ctime()})
# Create your views here.
def year_archive(request):
return HttpResponse("");
Views.py

例2:如何获取到地址栏中的年份(通过路由添加()匹配)


例3:给分组命名
urls中的配置
url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})$', views.year_archive),
views视图中的代码
return HttpResponse(year+"-"+month)

例四:注册小练习
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="" method="post">
<p>姓名 <input type="text" name="name"></p>
<p>年龄 <input type="text" name="age"></p>
<p>爱好 <input type="checkbox" name="hobby" value="">读书
<input type="checkbox" name="hobby" value="">写字
<input type="checkbox" name="hobby" value="">看报
</p>
<p><input type="submit"></p>
</form>
</body>
</html>
Register.html
from django.shortcuts import render,HttpResponse
import time
def show_time(request):
# return HttpResponse("Hello")
return render(request,"index.html",{"time":time.ctime()})
# Create your views here.
def year_archive(request,month,year):
return HttpResponse(year+"-"+month) def Register(request):
if request.method=="POST":
con="Hello,%s,你的年龄是%s"%(request.POST.get("name"),request.POST.get("age"))
return HttpResponse(con)
return render(request,"Register.html")
Views.py
"""django01 URL Configuration The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/2.1/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: path('', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
from django.conf.urls import url
from blog import views
urlpatterns = [
path('admin/', admin.site.urls),
path('show_time/',views.show_time),
url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})$', views.year_archive),
url(r'^Register/', views.Register), ]
urls.py
注意:需要把这句代码给注释掉

效果图


在url中给地址设置一个别名,这样后期Register名称的修改将不影响系统中其他调用的功能


URL分发


效果:

4:视图(Views)
http请求中产生两个核心对象:
http请求:HttpRequest对象
http响应:HttpResponse对象
4.1 HttpRequest对象的属性和方法:
4.2 HttpResponse对象:
页面渲染: render()(推荐)<br> render_to_response(),
页面跳转: redirect("路径")locals(): 可以直接将函数中所有的变量传给模板<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
4.1 HttpRequest对象的属性和方法: <br/>
姓名: {{ name}} <br/>
年龄:{{ age }} <br/>
路径:{{ reqPath }} <br/>
全路径:{{ reqFullPath }} <br/>
请求方法:{{ request.method }} <br/>
4.2 HttpResponse对象: <br/>
页面渲染:render()(推荐)<br>
页面渲染:render_to_response <br/> render_to_response(),
页面跳转: redirect("路径")
locals(): 可以直接将函数中所有的变量传给模板
</body>
</html>
新增一个Welcome的页面
from django.contrib import admin
from django.urls import path
from django.conf.urls import url,include
from blog import views
urlpatterns = [
url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})$', views.year_archive),
url(r'^Register2/', views.Register,name='reg'),
url(r'^Welcome/', views.Welcome, name='we'),
]
配置url信息
from django.shortcuts import render,HttpResponse,render_to_response,redirect
import time
def show_time(request):
# return HttpResponse("Hello")
return render(request,"index.html",{"time":time.ctime()})
# Create your views here.
def year_archive(request,month,year):
return HttpResponse(year+"-"+month) def Register(request):
if request.method=="POST":
# name = request.POST.get("name")
# age =request.POST.get("age")
# reqPath= request.path
# reqFullPath = request.get_full_path()
# return redirect("../Welcome",locals())
Welcome(request)
return redirect("../Welcome", locals())
return render(request, "Register2.html") def Welcome(request):
name = "张三"
age = "李四"
reqPath = request.path
reqFullPath = request.get_full_path()
return render_to_response("Welcome.html",locals())
添加View方法

5:模板(HTML+逻辑控制代码)
5.1 变量
from django.shortcuts import render,HttpResponse,render_to_response,redirect
import time
def show_time(request):
# return HttpResponse("Hello")
return render(request,"index.html",{"time":time.ctime()})
# Create your views here.
def year_archive(request,month,year):
return HttpResponse(year+"-"+month) def Register(request):
if request.method=="POST":
# name = request.POST.get("name")
# age =request.POST.get("age")
# reqPath= request.path
# reqFullPath = request.get_full_path()
# return redirect("../Welcome",locals())
Welcome(request)
return redirect("../Welcome", locals())
return render(request, "Register2.html") def Welcome(request):
name = ['zhangsan','lisi']
age = "李四1"
reqPath = request.path
reqFullPath = request.get_full_path()
return render_to_response("Welcome.html",locals())
class CVariable():
def __init__(self,name,age):
self.name=name
self.age = age
def Variable(request):
test1='字符串变量直接显示'
test2=['apples', 'bananas', 'carrots']
test3={"name":"字典名称","age":12}
test4=CVariable("张三",12)
return render(request,"Variable.html",locals())
def Variable(request):
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
{% load staticfiles %}
</head>
<body>
<p>字符串变量:{{ test1 }}</p>
<p>数组变量:{{ test2.1 }}</p>
<p>字典变量:{{ test3.name }}</p>
<p>类变量:{{ test4.age }}</p>
<p>转大写:{{ test2.1.upper }}</p>
</body>
</html>
HTML-{{}}和万能的.

5.2 过滤器
语法格式: {{obj|filter:param}}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
{% load staticfiles %}
</head>
<body>
<p>字符串变量:{{ test1 }}</p>
<p>数组变量:{{ test2.1 }}</p>
<p>字典变量:{{ test3.name }}</p>
<p>类变量:{{ test4.age }}</p>
<p>转大写:{{ test2.1.upper }}</p>
<p>---------我是过滤器的分割线-----------</p>
<p>过滤器转大写:{{ test2.1|upper }}</p>
<p>过滤器+3:{{ test4.age|add:3 }}</p>
<p>过滤器移除a字符:{{ test2.1|cut:'a' }}</p>
<p>过滤器日期格式化:{{ test5|date:'Y-m-d' }}</p>
<p>过滤器判断是否为空:{{ test6|default:'空的' }}</p>
<p>过滤器判断是否None:{{ test7|default_if_none:"None值" }}</p>
<p>过滤器链接:{{ test8|safe }}</p>
<p>过滤器链接2:
{% autoescape off %}
{{ test8 }}
{% endautoescape%}
</p>
<p>过滤器计算长度:{{ test2|length }}</p>
<p>过滤器取第一个元素:{{ test2|first }}</p>
</body>
</html>
过滤器

5.3 标签(tag)的使用
5.3.1 if 和for
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
{% load staticfiles %}
</head>
<body>
<p>字符串变量:{{ test1 }}</p>
<p>数组变量:{{ test2.1 }}</p>
<p>字典变量:{{ test3.name }}</p>
<p>类变量:{{ test4.age }}</p>
<p>转大写:{{ test2.1.upper }}</p>
<p>---------我是过滤器的分割线-----------</p>
<p>过滤器转大写:{{ test2.1|upper }}</p>
<p>过滤器+3:{{ test4.age|add:3 }}</p>
<p>过滤器移除a字符:{{ test2.1|cut:'a' }}</p>
<p>过滤器日期格式化:{{ test5|date:'Y-m-d' }}</p>
<p>过滤器判断是否为空:{{ test6|default:'空的' }}</p>
<p>过滤器判断是否None:{{ test7|default_if_none:"None值" }}</p>
<p>过滤器链接:{{ test8|safe }}</p>
<p>过滤器链接2:
{% autoescape off %}
{{ test8 }}
{% endautoescape%}
</p>
<p>过滤器计算长度:{{ test2|length }}</p>
<p>过滤器取第一个元素:{{ test2|first }}</p>
<p>---------我是标签tag的分割线-----------</p>
---if 判断---<br/>
{% if test4.age > 20 %}
{% if test4.age > 50 %}
<p>年龄在:50以上</p>
{% else %}
<p>年龄在:20-50之间</p>
{% endif %}
{% elif test4.age < 10 %}
<p>年龄在:10以下</p>
{% else %}
<p>年龄在:10-20 之间</p>
{% endif %}
---for 判断---<br/>
{% for item in test2 %}
{% if forloop.first %}
<p style="color: red">序号:{{ forloop.counter }},名称:{{ item }}</p>
{% else %}
<p>序号:{{ forloop.counter }},名称:{{ item }}</p>
{% endif %}
{% endfor %}
注意:<br/>
1,forloop.counter表示循环的次数,它从1开始计数,第一次循环设为1:<br/>
2,forloop.counter0 类似于forloop.counter,但它是从0开始计数,第一次循环设为0<br/>
3,forloop.revcounter<br/>
4,forloop.revcounter0<br/>
5,forloop.first当第一次循环时值为True,在特别情况下很有用:<br/>
---if 判断---<br/> </body>
</html>

5.3.2 {%csrf_token%}
用于生成csrf_token的标签,用于防治跨站攻击验证。注意如果你在view的index里用的是render_to_response方法,不会生效
其实,这里是会生成一个input标签,和其他表单标签一起提交给后台的。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
{% load staticfiles %}
</head>
<body>
<form action="{% url 'reg' %}" method="post">
<p>姓名 <input type="text" name="name"></p>
<p>年龄 <input type="text" name="age"></p>
<p>爱好 <input type="checkbox" name="hobby" value="">读书
<input type="checkbox" name="hobby" value="">写字
<input type="checkbox" name="hobby" value="">看报
</p>
<p><input type="submit"></p>
{%csrf_token%}
</form>
</body>
</html>
csrf_token
5.3.3 为复杂变量名起别名{% with %}:
---with 判断---<br/>
{% with test9test9test9test9test9test9test9 as a %}
{{ a }}
{% endwith %}
with
5.3.4 取消渲染
---取消渲染---<br/>
{% verbatim %}
{{adsf}}
{% endverbatim %}
取消渲染
5.3.5 引用路由配置的地址{% url %} 和 加载标签库{% load %}:

5.4 自定义过滤器
1:首先在app中创建templatetags模块
2:并在templatetags模块下创建.py文件,并设置自定义过滤器方法
# 导包
from django import template
from django.utils.safestring import mark_safe register = template.Library() #regkster的名字是固定的 @register.filter
def filter_multi(v1,v2):
return v1*v2
my_tag.py
3:在文件中引入{% load my_tags%}

效果:、

但是过滤器无法实现两个参数的传递,这时候需要simple_tag
# 导包
from django import template
from django.utils.safestring import mark_safe register = template.Library() #regkster的名字是固定的 @register.filter
def filter_multi(v1,v2):
return v1*v2 @register.simple_tag
def simple_tag_multi(v1,v2,v3):
return v1*v2*v3
my_tags.py

饮冰三年-人工智能-Python-22 Python初识Django的更多相关文章
- 饮冰三年-人工智能-Python-21 Python数据库MySql
一:下载与安装 1:下载地址:https://dev.mysql.com/downloads/mysql/ 2:安装MySql 打开下载文件解压到指定文件目录.(我这里解压目录为D:\MySql\my ...
- 饮冰三年-人工智能-Python-20 Python线程、进程、线程
进程:最小的数据单元 线程:最小的执行单元 一: 1:线程1 import threading #线程 import time def Music(): print("Listen Musi ...
- 饮冰三年-人工智能-Python-19 Python网络编程
Socket:套接字.作用:我们只需要安照socket的规定去编程,就不需要深入理解tcp/udp协议也可以实现 1:TCP协议 1.1 客户端服务端循环收发消息 # 1:引入stock模块(导包) ...
- 饮冰三年-人工智能-Python-10之C#与Python的对比
1:注释 C# 中 单行注释:// 多行注释:/**/ python 中 单行注释:# 多行注释:“““内容””” 2:字符串 C#中 "" 用双引号如("我是字符串&q ...
- 饮冰三年-人工智能-linux-08 软件包管理(Python的安装)
1:软件包存放的位置 media/CentOS_6.9_Final/Packages文件夹下 2.RPM就是Red Hat Package Manger(红帽软件包管理工具)的缩写. 2.1 常用的命 ...
- 饮冰三年-人工智能-Python-30 python开发中常见的错误
1:触发条件:创建的实体类生成到数据库表时报错 报错信息:TypeError: __init__() missing 1 required positional argument: 'on_delet ...
- 饮冰三年-人工智能-Python-23 Python PyCharm 使用中常见的问题
一:软件工具使用中遇到的问题 1:AttributeError: module 'pip' has no attribute 'main'问题 处理方法: a:找到JetBrains\PyCharm ...
- 饮冰三年-人工智能-Python-18Python面向对象
1 类与实例对方法和属性的修改 class Chinese: # 这是一个Chinese的类 #定义一个类属性,又称为静态数据或者静态变量,相当于C#中的static country="Ch ...
- 饮冰三年-人工智能-Python-16Python基础之迭代器、生成器、装饰器
一:迭代器: 最大的特点:节省内存 1.1 迭代器协议 a:对象必须提供一个next方法, b:执行方法要么返回迭代中的下一项,要么抛弃一个Stopiteration异常, c:只能向后不能向前. 1 ...
随机推荐
- linux 运维工程师发展路线
linux运维发展常见的就是下面两条路线:第一条:运维应用-->系统架构-->运维开发-->系统开发第二条:运维应用-->应用dba-->架构dba-->开发DBA ...
- CLOUD清理临时表空间
--查找空间名.物理空间路径 SELECT name, physical_nameFROM sys.master_filesWHERE database_id = DB_ID('tempdb'); 可 ...
- RPM Database 实战详解
RPM 是 RPM Package Manager 的简写,是发源于 Red-hat 系统的软件管理工具,所以最初的名字叫做 Red-hat Packager Manager.目前,RPM 已发展成为 ...
- Python——封装
广义上面向对象的封装:代码的保护,面向对象的思想本身是一种保护,只让自己的对象能调用自己累的方法 狭义上的封装——面向对象的三大特性之一 属性.方法都隐藏起来,不让你看见 规则: 1.所有的私有,都 ...
- [powershell] 批量重命名,修改文件名中的部分字符串
实例:替换一个目录下所有的字幕文件从720p到1080p ls $Path -Recurse |ForEach-Object{Rename-Item $_.FullName $_.FullName.R ...
- Codeforces 1037E Trips
原题 题目大意: 有\(n\)个人,起初他们都不是朋友.总共有\(m\)天,每天会有两个人成为朋友.他们计划在晚上出去旅游,对于一个人,有如下两种情况: 1.要么他不出去旅游 2.要么有至少\(k\) ...
- Mybatis的应用2 使用mybits+SpringBoot完成第一个查询的demo(随后加增加,更新,删除)
首先在mapper下面新建一个mysql.xml mysql.xml <?xml version="1.0" encoding="UTF-8" ?> ...
- FreeNAS:创建 CIFS 共享(权限)
第一部分:新建账户与指定数据集权限 简单起见,本教程主要介绍带基本身份验证的 CIFS 共享,即只有输入正确的用户名和密码才可以访问共享目录.关于创建匿名共享.多用户权限管理以及域控制器相关内容,我们 ...
- prometheus rules
prometheus 持久查询 有三种方法可以使我们的持久查询(不用每次都要输入查询规则): 记录规则 - 从查询中创建新的指标. 警报规则 - 从查询生成警报. 可视化 - 使用像Gra ...
- Docker:dockerfile镜像的分层 [九]
一.docker镜像的分层 1.图像呈现 2.命令呈现 [root@oldboy kod]# docker image history kod:v1 IMAGE CREATED CREATED BY ...