饮冰三年-人工智能-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 ...
随机推荐
- java异常处理规范
异常处理的优势[存在意义]:异常检测者有检测出异常的能力,但不知道在出现该异常的情况下应该怎么处理.故库方法一般会抛出异常给调用者来处理.所以总结而言,异常处理的优势就是,将处理错误(调用者处理)从检 ...
- fiddler抓包App数据
在做手机或移动端APP的接口测试时,需要从开发人员那里获取接口文档,接口文档应该包括完整的功能接口.接口请求方式.接口请求URL.接口请求参数.接口返回参数.如果当前项目没有接口文档,则可以使用fid ...
- Vue CLI 3使用:浏览器兼容性
package.json 文件里的 browserslist 字段 (或一个单独的 .browserslistrc 文件),指定了项目的目标浏览器的范围.这个值会被 @babel/preset-env ...
- Linux 学习 (四) 帮助命令
Linux达人养成计划 I 学习笔记 man 命令 获取指定命令的帮助 man的级别 1:查看命令的帮助 2:查看可被内核调用的函数的帮助 3:查看函数和函数库的帮助 4:查看特殊文件的帮助(主要是/ ...
- PHP——判断是否为加密协议https
前言 就是一个封装的方法,用来判断域名前面是加http还是https 代码 function is_ssl() { if(isset($_SERVER['HTTPS']) && ('1 ...
- rest framework 视图,路由
视图 在上面序列化的组件种已经用到了视图组件,即在视图函数部分进行逻辑操作. 但是很明显的弊端是,对每个表的增删改查加上 单条数据,需要用到 2个类 5个方法(增删改查,单数据查)才可以完整的实现,当 ...
- JavaJDBC整理
1.1.1 导入驱动jar包 创建lib目录,用于存放当前项目需要的所有jar包 选择jar包,右键执行build path / Add to Build Path 前版本 package co ...
- 静态IP设置
先查看自动网络的ip地址,然后设置 cmd进入DOS输入命令:ipconfig /all 设置固定IP
- Spark源码剖析 - SparkContext的初始化(一)
1. SparkContext概述 注意:SparkContext的初始化剖析是基于Spark2.1.0版本的 Spark Driver用于提交用户应用程序,实际可以看作Spark的客户端.了解Spa ...
- sqlserver 生成脚本执行创建索引
create or alter proc SP_CreateIndex as begin if exists(select * from sys.objects where name='execsql ...