一、安装:

1、安装Django环境:

# 安装
pip install django==5.0.3

# 验证 5.0.3
python -m django --version

安装慢的解决方法:使用阿里云的镜像源

pip install -i https://mirrors.aliyun.com/pypi/simple django==5.0.3

2、创建项目:

django-admin startproject mysite

可以看到,创建的目录结构:

mysite/
    manage.py
    mysite/
        __init__.py
        settings.py
        urls.py
        asgi.py
        wsgi.py

说明:

  1. 最外层的 mysite/ 根目录只是你项目的容器, 根目录名称对 Django 没有影响,你可以将它重命名为任何你喜欢的名称。
  2. manage.py: 一个让你用各种方式管理 Django 项目的命令行工具。你可以阅读 django-admin 和 manage.py 获取所有 manage.py 的细节。
  3. 里面一层的 mysite/ 目录包含你的项目,它是一个纯 Python 包。它的名字就是当你引用它内部任何东西时需要用到的 Python 包名。 (比如 mysite.urls).
  4. mysite/__init__.py:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。如果你是 Python 初学者,阅读官方文档中的 更多关于包的知识。
  5. mysite/settings.py:Django 项目的配置文件。如果你想知道这个文件是如何工作的,请查看 Django 配置 了解细节。
  6. mysite/urls.py:Django 项目的 URL 声明,就像你网站的“目录”。阅读 URL调度器 文档来获取更多关于 URL 的内容。
  7. mysite/asgi.py:作为你的项目的运行在 ASGI 兼容的 Web 服务器上的入口。阅读 如何使用 ASGI 来部署 了解更多细节。
  8. mysite/wsgi.py:作为你的项目的运行在 WSGI 兼容的Web服务器上的入口。阅读 如何使用 WSGI 进行部署 了解更多细节。

3、启动服务器:

# 在manage.py同级目录下执行
python manage.py runserver 0.0.0.0:8000

 4、创建应用:

在manage.py 所在的目录下,然后运行这行命令来创建一个应用:

# 创建一个应用
python manage.py startapp polls

编写视图,打开 polls/views.py,把下面这些 Python 代码输入进去:

from django.shortcuts import HttpResponse

def index(request):
    return HttpResponse("Hello, world. You're at the polls index.")

映射url,在 polls 目录中创建一个 URL 配置,请创建一个名为 urls.py 的文件:

from django.urls import path

from . import views

urlpatterns = [
    path("", views.index, name="index"),
]

在根URLconf 文件中指定我们创建的 polls.urls 模块。在 mysite/urls.py 文件的 urlpatterns 列表里插入一个 include(), 如下:

from django.contrib import admin
from django.urls import include, path

urlpatterns = [
    path("polls/", include("polls.urls")),
    path("admin/", admin.site.urls),
]

函数 include() 允许引用其它 URLconfs。每当 Django 遇到 include() 时,它会截断与此项匹配的 URL 的部分,并将剩余的字符串发送到 URLconf 以供进一步处理。

注意:项目的settings.py中一定要在“INSTALLED_APPS”中把App名称“polls”加进去:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'polls'
]

测试,启动项目,访问http://127.0.0.1:8000/polls/

二、request方法

Django中的请求包含了很多方法,简单认识下:

返回json数据:

在Django中,可以使用JsonResponse类来返回JSON数据。

from django.http import JsonResponse
 
def my_view(request):
    data = {'key': 'value'}  # 你的数据字典
    return JsonResponse(data)

 如果你需要返回一个列表或者其他复杂的数据类型,JsonResponse会自动将其序列化为JSON。例如:

from django.http import JsonResponse
 
def my_view(request):
    data = [1, 2, 3, 4, 5]  # 你的数据列表
    return JsonResponse(data, safe=False)

注意,当你传递一个非字典类型的对象时,需要将safe参数设置为False,这样JsonResponse就不会期望传入的是一个字典了。

三、模板渲染:

在Django中,可以使用Django模板语言(DTL)来渲染模板。以下是一个简单的例子,展示了如何在Django视图中渲染一个模板,并将上下文数据传递给它。

首先,确保在你的Django项目的settings.py文件中配置了模板目录:

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [BASE_DIR / 'templates'],
        ...
    },
]

然后,创建一个模板文件template_name.html在你的模板目录中:

<!-- templates/template_name.html -->
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>My Template</title>
</head>
<body>
    <h1>Hello, {{ name }}!</h1>
</body>
</html>

接下来,在Django视图中渲染这个模板:

# views.py
from django.shortcuts import render
 
def my_view(request):
    context = {'name': 'World'}
    return render(request, 'template_name.html', context)

在上面的例子中,render函数负责加载模板并使用提供的上下文字典进行渲染。template_name.html模板中的{{ name }}标签将被替换为World,渲染后的HTML将返回给客户端。

也可以在App中创建模板目录然后在App中使用:

1、在App中创建templates目录;

2、在项目的settings.py中,在“INSTALLED_APPS”中把App名称加进去;

3、在App的templates目录中创建模板文件,在Django视图中渲染这个模板。

四、数据库

1、配置数据库连接

配置 settings.py 文件中的 DATABASES:

DATABASES = {
	'default': {
		# 数据库引擎,mysql、oracle等
		'ENGINE': 'django.db.backends.mysql',
		# 数据库的名字
		'NAME': 'django_demo',
		# 连接mysql数据库的用户名
		'USER': 'root',
		# 连接mysql数据库的密码
		'PASSWORD': '123456',
		# mysql数据库的主机地址
		'HOST': '127.0.0.1',
		# mysql数据库的端口号
		'PORT': '3306',
	}
}

2、Django 操作数据库

Django 操作数据库方式:

使用原生 SQL 语句操作

使用 ORM 模型来操作

3、Django 使用原生 SQL 语句

SQL 语句操作数据库

# 使用django封装好的connection对象,会自动读取settings.py中数据库的配置信息
from django.db import connection

# 获取游标对象
cursor = connection.cursor()
# 拿到游标对象后执行sql语句
cursor.execute("select * from book")
# 获取所有的数据
rows = cursor.fetchall()
# 遍历查询到的数据
for row in rows:
    print(row)

Python DB API

任何使用 Python 来操作 MySQL 的驱动程序都遵循这个规范。所以不管是使用 pymysql 还是是 mysqlclient ,他们的接口都是一样的。

4、Django 使用 ORM 模型

ORM 模型

ORM,全称Object Relational Mapping,中文叫做对象关系映射,通过ORM我们可以通过类的方式去操作数据库,而不用再写原生的SQL语句。通过把表映射成类,把行作实例,把字段作为属性,ORM在执行对象操作的时候最终还是会把对应的操作转换为数据库原生语句

ORM模型一般都是放在 app 的 models.py 文件中。每个app都可以拥有自己的模型。并且如果这个模型想要映射到数据库中,那么这个app必须要放在settings.py的INSTALLED_APP中进行安装

创建 ORM 模型

ORM 模型必须继承自django.db.models.Model

ORM 模型映射到数据库中,表名默认是模型名称的小写形式

from django.db import models

class User(models.Model):
    name = models.CharField(max_length=20,null=False)
    age = models.IntegerField(default=0)
    birthday = models.DateTimeField(default=datetime.now)

映射 ORM 模型到数据库

在命令行终端,进入到项目所在的路径,然后执行命令 python manage.py makemigrations 来生成迁移脚本文件

执行命令 python manage.py migrate来将迁移脚本文件映射到数据库中。

5、模型字段类型如下

  • AutoField:自增长类型,数据表的字段类型为整数,长度为11位。
  • BigAutoField:自增长类型,数据表的字段类型为bigint,长度为20位。
  • CharField:字符类型。
  • BooleanField:布尔类型。
  • CommaSeparatedIntegerField:用逗号分割的整数类型。
  • DateField:日期( Date)类型。
  • DateTimeField:日期时间( Datetime)类型。Decimal:十进制小数类型。
  • EmailField:字符类型,存储邮箱格式的字符串。
  • FloatField:浮点数类型,数据表的字段类型变成Double类型。IntegerField:整数类型,数据表的字段类型为11位的整数。
  • BigIntegerField:长整数类型。
  • IPAddressField:字符类型,存储Ipv4地址的字符串。
  • GenericIPAddressField:字符类型,存储Ipv4和Ipv6地址的字符串。
  • NullBooleanField:允许为空的布尔类型。
  • PositiveIntegerFiel:正整数的整数类型。
  • PositiveSmallIntegerField:小正整数类型,取值范围为0~32767。
  • SlugField:字符类型,包含字母、数字、下画线和连字符的字符串。
  • SmallIntegerField:小整数类型,取值范围为-32,768~+32,767。
  • TextField:长文本类型。
  • TimeField:时间类型,显示时分秒HH:MM[ :ss[.uuuuuu]]。
  • URLField:字符类型,存储路由格式的字符串。
  • BinaryField:二进制数据类型。
  • FileField:字符类型,存储文件路径的字符串。
  • ImageField:字符类型,存储图片路径的字符串。
  • FilePathField:字符类型,从特定的文件目录选择某个文件。

6、模型字段参数如下:

  • verbose_name:默认为None,在 Admin站点管理设置字段的显示名称。
  • primary_key:默认为False,若为True,则将字段设置成主键。
  • max_length:默认为None,设置字段的最大长度。
  • unique:默认为False,若为True,则设置字段的唯一属性。
  • blank:默认为False,若为True,则字段允许为空值,数据库将存储空字符串。
  • null:默认为False,若为True,则字段允许为空值,数据库表现为NULL。
  • db_index:默认为False,若为True,则以此字段来创建数据库索引。default:默认为NOT_PROVIDED对象,设置字段的默认值。
  • editable:默认为True,允许字段可编辑,用于设置Admin的新增数据的字段。
  • serialize:默认为True,允许字段序列化,可将数据转化为JSON格式。
  • unique_for_date:默认为None,设置日期字段的唯一性。
  • unique_for_month:默认为None,设置日期字段月份的唯一性。
  • unique_for_year:默认为None,设置日期字段年份的唯一性。choices:默认为空列表,设置字段的可选值。
  • help_text:默认为空字符串,用于设置表单的提示信息。
  • db_column:默认为None,设置数据表的列名称,若不设置,则将字段名作为数据表的列名。
  • db_tablespace:默认为None,如果字段已创建索引,那么数据库的表空间名称将作为该字段的索引名。注意:部分数据库不支持表空间。
  • auto_created:默认为False,若为True,则自动创建字段,用于一对一的关系模型。validators:默认为空列表,设置字段内容的验证函数。
  • error_messages:默认为None,设置错误提示。

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部