Python基础day54 Django2
配置文件的介绍
# 注册应用的 INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'app01.apps.App01Config', ] ################中间件############################################################# MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ] ################中间件############################################################# ROOT_URLCONF = 'day54_dj.urls' # 根路由的文件名 #######Django连接MySQL数据库的 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } LANGUAGE_CODE = 'zh-hans' TIME_ZONE = 'Asia/Shanghai'
静态文件的配置
# 以登录功能为例 <form action=""> action参数的三种情况: 1. 什么都不写,就是朝当前地址提交数据 2. 要么全写:http://127.0.0.1:8000/login/?username=&password= 3. 只写后缀 http://127.0.0.1:8000/login/ """ 我们知道静态模板文件都是放在templates文件夹中,如果没有这个文件夹就自己创建 我们一般把静态文件放在static文件夹中, 但是,需要我们自己手动创建出来这个文件夹 静态文件: 网站使用的CSS文件 网站使用的js文件 网站使用图片 网站使用的第三方库文件 jQuery、bootstrap等 """ # 我们还可以针对不同的功能对static文件夹里面的问价进行拆分 css js img ... # 看起来是对的,但是不能访问到 http://127.0.0.1:8000/static/bootstrap-3.4.1-dist/js/bootstrap.min.js # 你之前访问的地址都可以访问到,那是因为你在后端开设了可以访问的接口(理由) # 之所以你现在访问不到刚才的地址,是因为你在后端没有开设这样的一个可访问的接口(路由) # Django自动的帮我们写好了这样的接口 # 访问静态文件的令牌,以后你只要访问静态文件的路径,就要以/static/开头 STATIC_URL = '/vxcvxcvxcvxcvcx/' # 静态文件 STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static') ] # 动态解析路径 {% load static %} <script src="{% static 'js/jquery.min.js' %}"></script> <link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}"> <script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script>
request对象请求方法
if request.method == 'POST': # if request.method == 'GET': # 如何接受post提交过来的数据? print(request.POST) # <QueryDict: {'username': ['asd'], 'password': ['dsa']}> print(request.POST.get('username')) # zfq # print(request.GET) # <QueryDict: {'username': ['ASD'], 'password': ['SDA']}> # print(request.GET.get('username')) # ASD # print(request.GET.get()) # 获取最后一个 # print(request.GET.getlist() # 获取所有的
pycharm连接数据库
pycharm它也支持连接数据,Navicat连接数据库,大多数都是使用Navicat
Django连接MySQL
# 默认情况sqlite3 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } # 连接MySQL DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } # 解决bug的思路: 1. 就是print() 2. 看是否有日志 3. 看报错的信息去百度中搜索 4. 问问别人 # 连接MySQL数据的时候可能报错的解决办法: 1. 如果解释器版本导致的问题,直接改源码 def get_new_connection(self, conn_params): conn = Database.connect(**conn_params) conn.encoders[SafeText] = conn.encoders[six.text_type] # 先判断bytes是否存在于编码器中,如果在才执行操作 if bytes in conn.encoders: # 加上这句话 conn.encoders[SafeBytes] = conn.encoders[bytes] return conn 2. 解释器版本改为3.6的时候也会报错 Django的底层默认使用的是mysqldb模块,这个模块兼容性很差 # 我们还使用pymysql连接mysql,你要提前安装pymysql模块 Did you install mysqlclient or MySQL-python? # 怎么解决这个问题: 在项目的任意的__init__.py中加入下面两行代码 ***************************************************************************** import pymysql pymysql.install_as_MySQLdb() # 猴子补丁 # 这两行代码的意思就是把底层的mysqldb模块换成pymysql ***************************************************************************** 3. 除了使用mysqldb、pymysql之外还可以使用mysqlclient这个模块 # 你用了mysqlclient这个模块,就不用加上面那两句话了 # mysqlclient安装的时候可能会报各种错误 DATABASES = { # 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), # } 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'db9', 'HOST': '127.0.0.1', 'PORT': 3306, 'USER': 'root', 'PASSWORD': 'root', 'CHARSET': 'utf8' } }
Django中的ORM
什么是ORM:对象映射模型 # 以后在django中写根数据库相关的代码时候,就不用再写原生的SQL语句了,直接通过python代码来操作数据的增删改查. # orm的书写位置:在models.py中书写 # 概念 表 >>>>> 类名 记录 >>>>> 对象 字段 >>>>> 属性 # 创建出来一张表来 # 所有的类必须继承models.Model class User(models.Model): # 表名 # id int primary key auto_increment id = models.AutoField(primary_key=True) # username varchar(64) username = models.CharField(max_length=64) # password varchar(64) password = models.CharField(max_length=64) # 类写完之后,一定要做数据库迁移,真正的在数据库中生成表 ******************************************************************************** python36 manage.py makemigrations # 它的作用是把数据库的迁移记录保存下来 python36 manage.py migrate # 才是真正的把数据表创建出来 ********************************************************************************
ORM增删改查字段
class Author(models.Model): # 如果创建的表中有主键字段,并且主键字段的名字也叫id,那么可以直接省略id字段,会自动创建id字段。 name = models.CharField(max_length=64) password = models.CharField(max_length=64, default=None) # 增加字段,默认值可以为空或者其他 password1 = models.CharField(max_length=64, default=None) # 修改字段,直接修改 '''删除字段:直接注释掉或者删掉你需要删除的字段代码就好'''
ORM增删改查数据
# 如何查询 select * from author where username = jack and password = 123 # odjects: 小组件,里面封装了很多的方法 # res = models.Author.objects.filter(name=username, password=password).all() # 查询全部 默认and查询 # res = models.Author.objects.filter(name=username, password=password).first() # 查询第一条 默认and查询 # res=models.Author.objects.filter(name=username).filter(password=password)# 是and查询 res = models.Author.objects.create(name=username, password=password) # 往数据库中增加数据 # print(res) # print(res[0].name) # print(res[0].password)