python修改静态html_Python学习————静态文件配置

静态文件配置

# 登陆功能

"""

我们将html文件默认都放在templates文件夹下

我们将网站所使用的静态文件默认都放在static文件夹下

静态文件

前端已经写好了的 能够直接调用使用的文件

网站写好的js文件

网站写好的css文件

网站用到的图片文件

第三方前端框架

...

拿来就可以直接使用的

"""

# django默认是不会自动帮你创建static文件夹 需要你自己手动创建

一般情况下我们在static文件夹内还会做进一步的划分处理

-static

--js

--css

--img

其他第三方文件

"""

在浏览器中输入url能够看到对应的资源

是因为后端提前开设了该资源的借口

如果访问不到资源 说明后端没有开设该资源的借口

http://127.0.0.1:8000/static/bootstrap-3.3.7-dist/css/bootstrap.min.css

"""

# 静态文件配置

"""

****************************************************************

当你在写django项目的时候 可能会出现后端代码修改了但是前端页面没有变化的情况

1.你在同一个端口开了好几个django项目

一直在跑的其实是第一个django项目

2.浏览器缓存的问题

settings

network

disable cache 勾选上

*****************************************************************

"""

STATIC_URL = '/ooo/' # 类似于访问静态文件的令牌

"""如果你想要访问静态文件 你就必须以static开头"""

"""

/static/bootstrap-3.3.7-dist/js/bootstrap.min.js

/static/令牌

取列表里面从上往下依次查找

bootstrap-3.3.7-dist/js/bootstrap.min.js

都没有才会报错

"""

# 静态文件配置

STATICFILES_DIRS = [

os.path.join(BASE_DIR,'static'),

os.path.join(BASE_DIR,'static1'),

os.path.join(BASE_DIR,'static2'),

]

# 静态文件动态解析

{% load static %}

# form表单默认是get请求数据

http://127.0.0.1:8000/login/?username=jason&password=123

"""

form表单action参数

1.不写 默认朝当前所在的url提交数据

2.全写 指名道姓

3.只写后缀 /login/

"""

# 在前期我们使用django提交post请求的时候 需要取配置文件中注释掉一行代码

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',

]

request对象方法初识

request.method # 返回请求方式 并且是全大写的字符串形式

request.POST # 获取用户post请求提交的普通数据不包含文件

request.POST.get() # 只获取列表最后一个元素

request.POST.getlist() # 直接将列表取出

request.GET # 获取用户提交的get请求数据

request.GET.get() # 只获取列表最后一个元素

request.GET.getlist() # 直接将列表取出

"""

get请求携带的数据是有大小限制的 大概好像只有4KB左右

而post请求则没有限制

"""

def login(request):

# 返回一个登陆界面

"""

get请求和post请求应该有不同的处理机制

:param request: 请求相关的数据对象 里面有很多简易的方法

:return:

"""

# print(type(request.method)) # 返回请求方式 并且是全大写的字符串形式

# if request.method == 'GET':

# print('来了 老弟')

# return render(request,'login.html')

# elif request.method == 'POST':

# return HttpResponse("收到了 宝贝")

if request.method == 'POST':

return HttpResponse("收到了 宝贝")

return render(request, 'login.html')

pycharm链接数据库(MySQL)

"""

三个位置查找数据库相关

右侧上方database

左下方database

配置里面的plugins插件搜索安装

再没有卸载pycharm重新装

pycharm可以充当很多款数据库软件的客户端

参考截图和视频操作即可

需要提前创建好库

"""

django链接数据库(MySQL)

# 默认用的是sqkite3

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.sqlite3',

'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),

}

}

# django链接MySQL

1.第一步配置文件中配置

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.mysql',

'NAME': 'day60',

'USER':'root',

'PASSWORD':'admin123',

'HOST':'127.0.0.1',

'PORT':3306,

'CHARSET':'utf8'

}

}

2.代码声明

django默认用的是mysqldb模块链接MySQL

但是该模块的兼容性不好 需要手动改为用pymysql链接

你需要告诉django不要用默认的mysqldb还是用pymysql

# 在项目名下的init或者任意的应用名下的init文件中书写以下代码都可以

import pymysql

pymysql.install_as_MySQLdb()

Django ORM

"""

ORM. 对象关系映射

作用:能够让一个不用sql语句的小白也能够通过python 面向对象的代码简单快捷的操作数据库

不足之处:封装程度太高 有时候sql语句的效率偏低 需要你自己写SQL语句

类表

对象记录

对象属性记录某个字段对应的值

应用下面的models.py文件

"""

# 1 先去models.py中书写一个类

class User(models.Model):

# id int primary_key auto_increment

id = models.AutoField(primary_key=True)

# username varchar(32)

username = models.CharField(max_length=32)

# password int

password = models.IntegerField()

*************************# 2 数据库迁移命令*************************

python3 manage.py makemigrations 将操作记录记录到小本本上(migrations文件夹)

python3 manage.py migrate 将操作真正的同步到数据库中

# 只要你修改了models.py中跟数据库相关的代码 就必须重新执行上述的两条命令

******************************************************************

class User(models.Model):

# id int primary_key auto_increment

id = models.AutoField(primary_key=True,verbose_name='主键')

# username varchar(32)

username = models.CharField(max_length=32,verbose_name='用户名')

"""

CharField必须要指定max_length参数 不指定会直接报错

verbose_name该参数是所有字段都有的 就是用来对字段的解释

"""

# password int

password = models.IntegerField(verbose_name='密码')

class Author(models.Model):

# 由于一张表中必须要有一个主键字段 并且一般情况下都叫id字段

# 所以orm当你不定义主键字段的时候 orm会自动帮你创建一个名为id主键字段

# 也就意味着 后续我们在创建模型表的时候如果主键字段名没有额外的叫法 那么主键字段可以省略不写

# username varchar(32)

username = models.CharField(max_length=32)

# password int

password = models.IntegerField()

字段的增删改查

# 字段的增加

1.可以在终端内直接给出默认值

2.该字段可以为空

info = models.CharField(max_length=32,verbose_name='个人简介',null=True)

3.直接给字段设置默认值

hobby = models.CharField(max_length=32,verbose_name='兴趣爱好',default='study')

# 字段的修改

直接修改代码然后执行数据库迁移的两条命令即可!

# 字段的删

直接注释对应的字段然后执行数据库迁移的两条命令即可!

执行完毕之后字段对应的数据也都没有了

"""

在操作models.py的时候一定要细心

千万不要注释一些字段

执行迁移命令之前最好先检查一下自己写的代码

"""

# 个人建议:当你离开你的计算机之后一定要锁屏

数据的增删改查

# 今天只会介绍一点点 后面会详细的介绍

# 查

res = models.User.objects.filter(username=username)

"""

返回值你先看成是列表套数据对象的格式

它也支持索引取值 切片操作 但是不支持负数索引

它也不推荐你使用索引的方式取值

user_obj = models.User.objects.filter(username=username).first()

"""

filter括号内可以携带多个参数 参数与参数之间默认是and关系

你可以把filter联想成where记忆

# 增

from app01 import models

res = models.User.objects.create(username=username,password=password)

# 返回值就是当前被创建的对象本身

# 第二种增加

user_obj = models.User(username=username,password=password)

user_obj.save() # 保存数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值