Django学习之小试牛刀

六、Django学习之小试牛刀


其他关于Python Web开发笔记:(如果遇到问题可以一起交流~)

一、Flask学习之HTML-CSDN博客

二、Flask学习之CSS-CSDN博客

【接上篇】二、Flask学习之CSS(下篇)-CSDN博客

三、Flask学习之BootSrap-CSDN博客

四、Flask学习之JavaScript-CSDN博客

五、Flask学习之MySQL-CSDN博客

1.安装Django

使用如下命令下载Django,会自动根据你的Python版本安装对应版本的Django:

text 复制代码
pip install Django

下载完成后进入到你的Python解释器的文件夹(安装Django的那个),然后再Script文件夹中会有一个名为django-admin.exe的文件,这个程序是用来帮助你创建Django项目的,如果没有,说明你的Django没有下载成功。

2.创建Django项目

创建Django项目有两种方式:

  • 使用django-admin.exe程序创建(新手推荐)

    首先打开终端,进入到你想要存放Django项目的文件夹,然后执行以下命令:

    text 复制代码
    django-admin startproject mysite

    注意:如果你没有把django-admin添加到环境变量,就需要把django-admin替换为django-admin的路径,例如:"D:\Anaconda\envs\Djangopro\Scripts\django-admin.exe"

  • 使用Pycharm(专业版)自带的Django项目

    在新建项目里面找到Django,然后输入你的项目名称,存放路径,Python解释器环境,就直接创建好了

两种方式创建出来的项目有区别,后面会讲到有什么区别

上面两种方式创建的目录结构稍有不同,建议使用第一种

text 复制代码
mysite/
    manage.py
    mysite/
        __init__.py
        settings.py
        urls.py
        asgi.py
        wsgi.py

官方文档\]([编写你的第一个 Django 应用,第 1 部分 \| Django 文档 \| Django (djangoproject.com)](https://docs.djangoproject.com/zh-hans/4.2/intro/tutorial01/))对这些文件的介绍是这样的: > 这些目录和文件的用处是: > > * 最外层的 `mysite/` 根目录只是你项目的容器, 根目录名称对 Django 没有影响,你可以将它重命名为任何你喜欢的名称。 > * `manage.py`: 一个让你用各种方式管理 Django 项目的命令行工具。你可以阅读 [django-admin 和 manage.py](https://docs.djangoproject.com/zh-hans/4.2/ref/django-admin/) 获取所有 `manage.py` 的细节。 > * 里面一层的 `mysite/` 目录包含你的项目,它是一个纯 Python 包。它的名字就是当你引用它内部任何东西时需要用到的 Python 包名。 (比如 `mysite.urls`). > * `mysite/__init__.py`:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。如果你是 Python 初学者,阅读官方文档中的 [更多关于包的知识](https://docs.python.org/3/tutorial/modules.html#tut-packages)。 > * `mysite/settings.py`:Django 项目的配置文件。如果你想知道这个文件是如何工作的,请查看 [Django 配置](https://docs.djangoproject.com/zh-hans/4.2/topics/settings/) 了解细节。 > * `mysite/urls.py`:Django 项目的 URL 声明,就像你网站的"目录"。阅读 [URL调度器](https://docs.djangoproject.com/zh-hans/4.2/topics/http/urls/) 文档来获取更多关于 URL 的内容。 > * `mysite/asgi.py`:作为你的项目的运行在 ASGI 兼容的 Web 服务器上的入口。阅读 [如何使用 ASGI 来部署](https://docs.djangoproject.com/zh-hans/4.2/howto/deployment/asgi/) 了解更多细节。 > * `mysite/wsgi.py`:作为你的项目的运行在 WSGI 兼容的Web服务器上的入口。阅读 [如何使用 WSGI 进行部署](https://docs.djangoproject.com/zh-hans/4.2/howto/deployment/wsgi/) 了解更多细节。 ### 3.测试Django 运行项目的方式有两种: * 直接使用PyCharm运行本项目 * 在终端使用命令`python manage.py runserver` 浏览器打开网址: http://127.0.0.1:8000/ 如果出现下面的小火箭就说明运行成功! ![sw](https://file.jishuzhan.net/article/1751535259352043522/bdd9720ab2738407348bcbd96e6ed72c.webp) ### 4.创建APP 在终端中运行下列代码: ```pyhton python manage.py startapp myapp01 ``` > 可以把APP想象成一个个模块,一个项目可以创建不同的APP,每个APP负责一个功能 在根目录会自动创建一个文件夹名为myapp01,目录结构为: ```text ├─myapp01 │ │ admin.py # 管理后台(一般不用) │ │ apps.py # 不要动 │ │ models.py # 对数据库进行操作(重要) │ │ tests.py # 单元测试 │ │ views.py # 视图,存放函数的地方 (重要) │ │ __init__.py │ │ │ └─migrations # 不要动 │ __init__.py ``` ### 5.简单页面 创建完成APP以后,Django并不会感知到APP,需要我们在settings.py文件中进行注册。 打开settings.py,修改INSTALLED_APPS: ```python INSTALLED_APPS = [ "django.contrib.admin", "django.contrib.auth", "django.contrib.contenttypes", "django.contrib.sessions", "django.contrib.messages", "django.contrib.staticfiles", "myapp01.apps.Myapp01Config" # 改成你的APP下的自己名称 ] ``` 编写视图和URL的关系: 打开urls.py:改成你网址的url ```python from django.urls import path from myapp01 import views urlpatterns = [ # path("admin/", admin.site.urls), path("index/", views.index) ] ``` 函数path具有四个参数([官方文档](https://docs.djangoproject.com/zh-hans/4.2/intro/tutorial01/)),两个必须参数:`route` 和 `view`,两个可选参数:`kwargs` 和 `name` * route `route` 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 `urlpatterns` 的第一项开始,按顺序依次匹配列表中的项,直到找到匹配的项。 这些准则不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 `https://www.example.com/myapp/` 时,它会尝试匹配 `myapp/` 。处理请求 `https://www.example.com/myapp/?page=3` 时,也只会尝试匹配 `myapp/`。 * view 当 Django 找到了一个匹配的准则,就会调用这个特定的视图函数,并传入一个 `HttpRequest`对象作为第一个参数,被"捕获"的参数以关键字参数的形式传入。 * kwargs 任意个关键字参数可以作为一个字典传递给目标视图函数。 * name 为你的 URL 取名能使你在 Django 的任意地方唯一地引用它,尤其是在模板中。这个有用的特性允许你只改一个文件就能全局地修改某个 URL 模式。 然后修改你的views.py里面的代码: ```python from django.http import HttpResponse def index(request): return HttpResponse("Hello, world!") ``` 运行本项目,在浏览器框中输入http://localhost:8000/index/ 然后得到结果: ![在这里插入图片描述](https://file.jishuzhan.net/article/1751535259352043522/acf47658556fbd8701f91ca93238752b.webp) ### 6.模板和静态文件 #### 6.1模板 模板是你存放HTML文件的地方,使用Pycharm创建的项目和使用官方提供的方法创建的目录会有所不同。具体可以参见官方文档,去settings.py里面修改。这里以使用官方方法创建的项目目录为例: 在上面==**已经创建好的app文件夹中创建文件夹templates**==,然后可以新建HTML > 在py文件索引HTML文件的时候,会按照appd的注册顺序去寻找 这里新建一个页面user_list.html为例,首先要在urls.py里面添加url: ```python path("user/list/", views.user_list) ``` 然后去views.py里面创建对应的函数: ```python from django.http import HttpResponse from django.shortcuts import render def user_list(request): return render(request, "user_list.html") ``` 随后在templates里面创建文件user_list.html ```html Title

用户列表

``` 然后运行就能得到结果。 #### 6.2静态文件 同样使用官方法创建的项目为例,static目录是用来存放css、js、照片等插件的地方。**已经创建好的app文件夹中创建文件夹static**,然后将下载好的js,bootsrap复制过来 myapp01目录结构 ```text ├─static │ ├─css │ ├─img │ ├─js │ └─plugins │ └─bootstrap-3.4.1-dist │ ├─css │ ├─fonts │ └─js ├─templates ``` 继续美化上面的user_list.html: ```html {% load static %} {# 加载static文件夹,方便项目找到static下面的文件 #} Title {# 引入bootsrap #}

用户列表

{##} {# 引入js #} ``` 得到结果: ![image-20240127231223951](https://file.jishuzhan.net/article/1751535259352043522/6b078498da8fe71bdd8137dc390a3b42.webp)

相关推荐
橘猫云计算机设计19 分钟前
springboot基于hadoop的酷狗音乐爬虫大数据分析可视化系统(源码+lw+部署文档+讲解),源码可白嫖!
数据库·hadoop·spring boot·爬虫·python·数据分析·毕业设计
YOULANSHENGMENG24 分钟前
linux 下python 调用c++的动态库的方法
c++·python
SsummerC41 分钟前
【leetcode100】零钱兑换Ⅱ
数据结构·python·算法·leetcode·动态规划
一眼青苔1 小时前
切割PDF使用python,库PyPDF2
服务器·python·pdf
电子云与长程纠缠1 小时前
Unreal Niagara制作SubUV贴图翻页动画
学习·ue5·编辑器·贴图·niagara
电商数据girl1 小时前
产品经理对于电商接口的梳理||电商接口文档梳理与接入
大数据·数据库·python·自动化·产品经理
三道杠卷胡2 小时前
【AI News | 20250424】每日AI进展
人工智能·pytorch·python·语言模型·github
xing_x_xx2 小时前
Linux系统学习----概述与目录结构
学习
DKPT2 小时前
常见正则表达式整理与Java使用正则表达式的例子
java·笔记·学习·面试·正则表达式
T糖锅G2 小时前
小白自学python第二天
python