只要先添加功能,就去urls.py 和 view.py中添加对应和功能函数
当识别到项目中代码有变化之后,间隔一段时间之后就会自动重启,但会有点慢
HttpResponse
主要用于返回字符串类型的数据
return HttpResponse

render
主要用于返回html文件,并且支持模板语法(django语法)
return render(request, 'index文件.html', {'name': 'gavin'})

redirect
主要用于重定向,括号内的可以写其他网站的全称,也可以写自己网站的后缀


"""
我们之所以可以在浏览器地址栏中输入不同的路由访问到不同的资源 是因为我们在后端框架中提前开设了相应的访问接口所以用户才能访问
言外之意就是我们没有开设接口 那么肯定访问不到
"""
静态文件
form表单
action参数: 控制数据的提交地址
method参数: 控制请求的提交方式
静态文件全部显示资源不存在
http://127.0.0.1:8000/static/bootstrap-3.3.7-dist/css/bootstrap.min.css
就是因为我们没有开设惊涛资源的访问端口
理论上是自己去路由层开设接口资源,但是由于静态文件资源使用频率很高
因为只要是一个web项目肯定需要开设,使用提供了静态资源的配置文件,只要填写固定的配置就可以开设资源接口
settings.py文件中,最下方
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static')
]
/static/mycss.css
STATIC_URL = '/static/'
STATICFILES_DIRS = []
"""
以该地址为例:/static/bootstrap-3.3.7-dist/css/bootstrap.min.css
/static/是接口前缀 表示具备访问静态文件资源的权限
具备了权限之后会拿着接口前缀后面的文件路径去列表中每个文件夹中查找
bootstrap-3.3.7-dist/css/bootstrap.min.css
找到一个就结束
比如 static和static1里面都有a.txt 那么只会拿到static中的
"""
如果templates中有很多html文件并且都需要引入静态资源
当你把接口的前缀修改之后页面就无法加载资源,使用我们进行动态的接口前缀绑定
{% load static %}
<link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">

css文件、js文件、图片文件、第三方框架文件(bootstarp)
这些都可以称之为静态文件
我们在django中静态文件单独开设一个文件夹存储,默认为static文件夹
在这个文件夹内还可以根据功能的不同继续划分不同的文件
css文件夹、js文件夹、img文件夹 、others文件夹

"""
提交post请求,默认时会报403
前期我们直接去配置文件中注释一行即可
MIDDLEWARE = [
'django.middleware.csrf.CsrfViewMiddleware',
]
注释这一行
"""
1、get请求和post请求都会触发同一个视图函数login的运行
get请求返回一个登录页面
post请求获取用户数据并校验
2、获取当前请求方式
request.method 返回的是纯大写的请求方法字符串
"""
由于get请求更加常见,post请求其次,所以还可以简写
"""
"""默认让视图函数处理get请求 ,当为post时走post"""
if request.method == 'POST':
return HttpResponse('欢迎来到米奇妙妙屋')
return render(request, 'login.html')
3、获取post请求提交的普通数据
request.POST
print(request.POST.get('hobby'))
print(request.POST.getlist('hobby'))
4、如何获取URL后面携带的数据
print(request.GET)
print(request.GET.get('info'))
print(request.GET.getlist('city'))
特征与上述request.POST一致 使用场景也很多
https://www.lagou.com/wn/jobs?kd=python&isSchoolJob=1&city=%E4%B8%8A%E6%B5%B7&pn=1

"""
pycharm也可以充当很多数据库软件的客户端
"""
1、pycharm左上方侧边 database
2、pycharm左下方边 database
3、这两个地方都没有时,我们就需要下载插件,或者重新安装一个正常pycharm
settings
plugins
搜索database下载apple即可
1、选择数据库
2、首次链接需要下载驱动
download drive..
3、测试链接如果不通过,则需要换驱动重新下载使用
Driver:MySQL MySQL for 5.1

"""
django默认自带一个sqlite3数据库,但是功能很少,仅用于本地测试使用
"""
1.默认配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
2.修改配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'lsw03',
'HOST': '127.0.0.1',
'PORT': 3306,
'USER': 'root',
'PASSWORD': '123456',
}
在项目同名的文件夹内的__init__.py
或者应用名的文件夹内的__init__.py
添加一行固定的代码
import pymysql
pymysql.install_as_MySQLdb()

ORM:对象关系映射
能够让不会写SQL的python程序员使用Python语法就可以直接操作mysql
开发效率等得到提高
坏处: 封装了SQL语句,有时候效率不高还需要人为编写SQL调用
表 ———— 类
一行行数据 ———— 类产生的一个个对象
数据字段 ———— 对象的一个个属性
1、编写类代码,创建一个表
class Users(models.Model):
uid = models.AutoField(primary_key=True)
name = models.CharField(max_length=32)
pwd = models.IntegerField()
2、执行数据库迁移命令
python38 manage.py makemigrations
python38 manage.py migrate
"""
首次执行迁移命令 django还会自动创建一些默认需要使用到的表
"""
3、表名的特征
users app01_users
由于django支持多个应用 ,所以为了区分不同应用下可能会出现相同的表名 ,所以自动加上了应用的前缀,这样就会在一个人应用里面出现相同的表名
4、扩展
4.1、表的主键可以不写,orm会自动帮你写一个名为ID的主键
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
4.2、每次修改了跟数据局库相关的Python代码,都需要重新执行迁移命令
针对两个迁移的命令,可以采用pycharm提示功能编写
tools
run manage.py task

from app01 import models
user_obj = models.Users.objects.create(name='gavin', pwd='123')
print(user_obj)
print(user_obj.uid)
print(user_obj.name)
print(user_obj.pwd)
res = models.Users.objects.filter(name='owen')
print(res)
print(res[0])
print(res[0].uid)
print(res[0].name)
print(res[0].pwd)
models.Users.objects.filter(uid=2).update(name='gavinYYDS')
models.Users.objects.filter(uid=3).delete()

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人