python学习
Python3 下载
Python3 最新源码,二进制文档,新闻资讯等可以在 Python 的官网查看到:
Python 官网:https://www.python.org/
你可以在以下链接中下载 Python 的文档,你可以下载 HTML、PDF 和 PostScript 等格式的文档。
Python文档下载地址:https://www.python.org/doc/
Window 平台安装 Python3.6.8
以下为在 Window 平台上安装 Python 的简单步骤。
打开 WEB 浏览器访问 https://www.python.org/downloads/windows/,一般就下载 executable installer,x86 表示是 32 位机子的,x86-64 表示 64 位机子的。
![](https://img.haomeiwen.com/i25503794/8b9072a2af26ee4a.png)
记得勾选 Add Python 3.6 to PATH。
按 Win+R 键,输入 cmd 调出命令提示符,输入 python:
![](https://img.haomeiwen.com/i25503794/7c00bc115456d554.png)
vscode安装
1、打开项目代码,选择项目需要的python虚拟环境
![](https://img.haomeiwen.com/i25503794/0bb570cf3a799967.png)
2、安装项目依赖包
pip install -r requirements.txt
django项目创建
1、vscode中创建test文件夹,新建python虚拟环境
![](https://img.haomeiwen.com/i25503794/9d51da69b83d3baf.png)
2、pip istall Django==2.2.6 安装Django
![](https://img.haomeiwen.com/i25503794/b9ca99c3a4a4a75d.png)
![](https://img.haomeiwen.com/i25503794/aca93115ae2dd212.png)
3、输入django-admin startproject 创建项目名称 的格式就可以创建出django项目。eg: django-admin startproject mysite
![](https://img.haomeiwen.com/i25503794/063f14544b7a206f.png)
4、创建app功能模块
终端进入mysite目录进行添加app(功能模块),输入格式:python manage.py startapp app名称。eg:python manage.py startapp app01。
![](https://img.haomeiwen.com/i25503794/92c7bfa38ec44ffb.png)
5、启动运行django项目程序
在settings.py中注册app,在配置文件中添加来自apps.py的类。
![](https://img.haomeiwen.com/i25503794/ffcf9ed715c321c6.png)
![](https://img.haomeiwen.com/i25503794/d0bf027df970c7c4.png)
在urls.py中注释掉原来的path并编写新的url和视图函数的对应关系。
![](https://img.haomeiwen.com/i25503794/d993b98818ac2afa.png)
在view.py中定义index函数,返回欢迎使用
![](https://img.haomeiwen.com/i25503794/224e84c94211e412.png)
后台模式运行python .\manage.py runserver
![](https://img.haomeiwen.com/i25503794/3c8857e3c8b5f1cf.png)
访问后页面返回
![](https://img.haomeiwen.com/i25503794/ffe273e8c1caca68.png)
6、模板和静态文件的存放地址
模板其实就相当于是前端的html文件。
新建一个templates文件夹,里面存的东西都是模板。静态文件其实就包括css、js、image、plugins等。
![](https://img.haomeiwen.com/i25503794/18709023dc52334e.png)
以图片为例
url中定义rul和视图对应关系
![](https://img.haomeiwen.com/i25503794/72fe97d266a78671.png)
在视图函数中使用render返回模板
![](https://img.haomeiwen.com/i25503794/6dc4c71437f45bca.png)
模版中加载静态资源图片
![](https://img.haomeiwen.com/i25503794/b6119e0c21b6f1e4.png)
{% load static %}
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, user-scalable=no">
<meta http-equiv="X-UA-Compatible" content="ie=edqe">
<title>Document</title>
</head>
<body>
<h1>用户列表</h1>
<img src="{% static "image/avatar2.png" %}" >
</body>
</html>
实际展示
![](https://img.haomeiwen.com/i25503794/050c45f4f1e30c66.png)
7、django中的模板语法
django与Java那边的SpringBoot是完全不一样的,SpringBoot在开发中讲究的是前后端分离,但是django这边不是为前后端分离设计的,所以前后端代码的耦合度更高,比较适合于个人的独立开发,所以django进而就存在了模板语法这种东西。
而模板语法,本质上就是在html中写一些占位符,由后端传来的数据对这些占位符进行替换和处理操作。
以下演示一下模板语法的使用(以及附带一个django项目的执行流程),更多的模板语法还是需要查阅一下资料的,但是最常用的无非就是for来循环以及if来判断
步骤一:在urls.py中添加path路径。
![](https://img.haomeiwen.com/i25503794/039e0157ef3c2efd.png)
步骤二:在views.py中添加视图函数,构造并传递数据给模板。
![](https://img.haomeiwen.com/i25503794/44aa4cea5257d1c3.png)
def news(request):
import requests
url = 'https://www.chinaunicom.com.cn/43/menu01/1/column05'
header = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Safari/537.36 Core/1.70.3775.400 QQBrowser/10.6.4208.400'
}
res = requests.get(url=url, headers=header)
data_list = res.json()
print(data_list)
return render(request, 'news.html', {'news_list': data_list})
在模板接收数据并组织显示到页面。
![](https://img.haomeiwen.com/i25503794/2454d60bcd5172ec.png)
django项目整体的执行流程:
![](https://img.haomeiwen.com/i25503794/3b649a6d552c9b6f.png)
用户操作流程
![](https://img.haomeiwen.com/i25503794/a78cb6f2910a0d54.png)
解析:
用户通过浏览器向我们的服务器发起一个请求(request),这个请求会去访问视图函数:
a.如果不涉及到数据调用,那么这个时候视图函数直接返回一个模板也就是一个网页给用户。
b.如果涉及到数据调用,那么视图函数调用模型,模型去数据库查找数据,然后逐级返回。
视图函数把返回的数据填充到模板中空格,最后返回网页给用户。
8、django中常见的请求和响应
三种常见的请求:
第一种:获取请求的方式:GET/POST(request.method)。
第二种:在url上传递值(request.GET)。
第三种:在请求体中提交数据(request.POST)。
![](https://img.haomeiwen.com/i25503794/76897f0fb6ab2634.png)
![](https://img.haomeiwen.com/i25503794/e84a5c0f09a3ff18.png)
![](https://img.haomeiwen.com/i25503794/fc1410c220b3d687.png)
三种常见的响应:
第一种:直接将响应字符串内容返回给请求者。
第二种:读取模板/html内容+渲染再返回给请求者。
第三种:返回重定向结果给请求者。
![](https://img.haomeiwen.com/i25503794/8bf0fb4ef9e29d24.png)
9、连接MySQL数据库
在接触Django框架之前,我们对Python进行数据库连接以及增删改查的操作都是基于pymysql库进行的,但是这有一个缺点:每次执行之前都需要对数据库进行连接以及编写大量增删改查的语句,总体来说是比较繁琐的。到了Django框架这边,由于其内部提供了ORM框架,所以使用起来就会变得方便许多。这就有点类似于Java那边的JDBC和MyBatis的区别了。
安装第三方模块
由于Django新版底层依赖的pymysql比较差,所以现在我们就比较少使用pymysql,本文会以mysqlclient来进行演示。:
pip install mysqlclient #出错
![](https://img.haomeiwen.com/i25503794/37be428cb71a4278.png)
下载安装包 https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysqlclient
![](https://img.haomeiwen.com/i25503794/fa635b53d3643166.png)
安装下载的安装包
![](https://img.haomeiwen.com/i25503794/7b81fad20502e47b.png)
ORM框架:
ORM框架主要的作用是:
创建、修改、删除数据库中的表。(注意:只能针对表操作,无法进行创建数据库,创建数据库只能通过自己的MySQL终端进行创建)
操作表中的数据(也就是对表进行增删改查操作)。
步骤一:创建数据库(eg:create database django_mytest default charset utf8 collate utf8_general_ci;)
步骤二:使用django连接MySQL数据库
django默认使用的数据库是sqlite,而我们现在使用的是MySQL数据库,所以我们就需要在settings.py文件里面修改一下配置。
选中要注释的代码块:Ctrl+/;取消注释:Ctrl+/
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'django_mytest', # 刚才创建数据库的名字
'USER': '用户名',
'PASSWORD': '密码', # 自己数据库的密码
'HOST': '数据库地址', # 安装MySQL的机器(默认这里都是主机安装)
'PORT': '3366', # 设置端口号(默认3306)
}
}
使用ORM框架操作数据库
创建&删除表:
步骤一:在models.py文件中创建类:
# Create your models here.
class UserInfo(models.Model):
name = models.CharField(max_length=32)
password = models.CharField(max_length=64)
age = models.IntegerField()
步骤二:在vsc终端输入命令:
python manage.py makemigrations
python manage.py migrate
![](https://img.haomeiwen.com/i25503794/e17ae3af78fe8b4f.png)
![](https://img.haomeiwen.com/i25503794/5cb3e6612395cd23.png)
注意:在以后新增表或者删除表的时候只需要在这里选择填写或者注释掉之后,再重新运行上面两个命令即可做到新增或者删除表。
修改表结构:
在表中新增列的时候,由于已经存在的列中可能有数据了,所以在新增列的时候就必须要指定新增列对应的数据(具体有四种做法):
1、在终端会进行提示,可以在终端手动输入一个值。
2、设置默认值。eg:age = models.IntegerField(default=10)。
3、允许为空。eg:age = models.IntegerField(null=True, blank=True)。
4、如果你可以确定表中一定是没有数据的,或者是已经想删除表中的数据的,可以先注释掉运行,再注释回来添加列再输入上面两行命令运行,但是还是不推荐这样子做。
对表中数据进行增删改查操作:
1、增
![](https://img.haomeiwen.com/i25503794/280fc3446ca135e7.png)
![](https://img.haomeiwen.com/i25503794/dbd68f04d511b4f9.png)
2、删
![](https://img.haomeiwen.com/i25503794/d94fffbecf106110.png)
![](https://img.haomeiwen.com/i25503794/c9dca428c25609e7.png)
3、改
![](https://img.haomeiwen.com/i25503794/b9c79dc2b22b46dc.png)
![](https://img.haomeiwen.com/i25503794/37c9f0fe576aa9c7.png)
问题
1、数据库建表时, 没有成功创建表 No migrations to apply报错原因和解决方法
错误原因是因为在之间就已经执行过python manage.py migrate,在数据库表django_migrations中有之前的信息导致无法正常建表。
解决方法:
打开数据库找到django_migrations
删除其中name为0001_initial的那条记录,然后在重新执行python manage.py migrate就可以正常建表