Python-Django入手

发布于:2025-04-01 ⋅ 阅读:(32) ⋅ 点赞:(0)

18.1 建立项目

18.1.1 制定规范

- 定义项目目标:明确应用的核心功能

- 创建项目文档:用README.md记录技术栈和开发流程

- 规划目录结构:建议遵循Django官方推荐的项目布局

18.1.2 建立虚拟环境

在命令行执行:

python -m venv ll_env

说明:

- venv是Python内置虚拟环境模块

- ll_env是自定义环境名称,隔离项目依赖

18.1.3 激活虚拟环境

Windows系统:

ll_env\Scripts\activate.bat

Linux/macOS:

source ll_env/bin/activate

激活后命令提示符前显示(环境名)表示成功

18.1.4 安装Django

在激活的虚拟环境中执行:

pip install django==4.2.0

说明:

- 指定版本号可保证环境一致性

- pip是Python包管理器,自动处理依赖关系

18.1.5 创建Django项目

执行命令:

django-admin startproject learning_log .

说明:

- startproject是项目管理命令

- 末尾的.表示在当前目录创建项目

- 生成核心文件:settings.py, urls.py, wsgi.py等

18.1.6 创建数据库

执行迁移命令:

python manage.py migrate

功能说明:

- 生成默认的SQLite数据库文件db.sqlite3

- 创建Django内置应用(如admin,auth)的数据库表

18.1.7 查看项目

启动开发服务器:

python manage.py runserver

访问http://127.0.0.1:8000

出现火箭图标页面表示项目创建成功

18.2 创建应用程序

18.2.1 定义模型

在models.py中添加:

from django.db import models



class Topic(models.Model):

    text = models.CharField(max_length=200)

    date_added = models.DateTimeField(auto_now_add=True)



    def __str__(self):

        return self.text

语法解析:

- 继承models.Model创建数据模型

- CharField定义字符类型字段,必须指定max_length

- DateTimeField的auto_now_add参数自动设置创建时间

- __str__方法定义对象显示格式

18.2.2 激活模型

修改settings.py的INSTALLED_APPS:

INSTALLED_APPS = [

    ...

    'learning_logs',

]

执行迁移命令:

python manage.py makemigrations learning_logs

python manage.py migrate

说明:

- makemigrations生成迁移文件

- migrate应用数据库变更

18.3 创建页面

18.3.2 编写视图

示例视图函数:

from django.shortcuts import render



def index(request):

    return render(request, 'learning_logs/index.html')

功能说明:

- request参数包含HTTP请求信息

- render函数将模板渲染为HTML响应

- 模板路径遵循app/templates/app/结构

18.3.3 编写模板

创建templates/learning_logs/index.html:

<html>

    <head>

        <title>Learning Log</title>

    </head>

    <body>

        <h1>Learning Log Homepage</h1>

        <p>Welcome to your knowledge base.</p>

    </body>

</html>

模板语法说明:

- 使用标准HTML语法

- 后续可通过Django模板语言添加动态内容

18.4.1 模板继承

基础模板base.html:

<html>

    <head>

        <title>{% block title %}{% endblock %}</title>

    </head>

    <body>

        {% block content %}

        {% endblock %}

    </body>

</html>

子模板使用:

{% extends "learning_logs/base.html" %}



{% block title %}Topics{% endblock %}



{% block content %}

    <ul>

    {% for topic in topics %}

        <li>{{ topic.text }}</li>

    {% endfor %}

    </ul>

{% endblock %}

继承机制说明:

- extends声明继承关系

- block定义可替换内容区域

- 使用模板标签{% for %}实现循环逻辑

18.5 小结

本章完整流程:

1. 创建虚拟环境隔离依赖

2. 安装Django并初始化项目

3. 定义数据模型和业务逻辑

4. 通过视图函数处理请求

5. 使用模板系统渲染页面

6. 通过URL配置路由请求

关键命令总结:

- python manage.py startapp [应用名] 创建新应用

- python manage.py createsuperuser 创建管理员

- python manage.py shell 进入Django交互环境

注意:所有代码块中的缩进使用4个空格,Django严格要求语法格式。模型修改后必须执行迁移命令才能生效,模板文件需要放在正确目录路径下。


网站公告

今日签到

点亮在社区的每一天
去签到