最近在看Python编程:从入门到实践,这是这本书“项目3 Web应用程序”第18章的笔记。记录了django最基本的一些日常用法,以便自己查阅。

可能是我的这本书版本比较老,书上项目的代码直接跑跑不通,也有一些小小的错误。这里我做了一些修改。


基本用法

  • 创建项目 django-admin startproject 项目名 .
  • 创建数据库 python manage.py migrate
  • 查看项目 python manage.py runserver
  • 创建应用程序 python manage.py startapp 应用程序名

激活模型:

  • 在settings.py的INSTALLED_APPS中加入刚才创建的应用程序
  • 修改数据库,使其能够存储与模型相关的信息:

    python manage.py makemigrations 应用程序名

上述操作产生一个迁移文件(“0001_initial.py”),让Django应用这种迁移修改数据库:

python manage.py migrate

只要添加了新的模型,就需要重复上面两个命令再次迁移数据库。


  • 创建超级用户:python manage.py createsuperuser
  • 向管理网站注册模型:

    在admin.py中 from xxx.models import 模型名

    admin.site.register(模型名)

然后就能使用超级用户账户访问管理网站了:http://localhost:8000/admin/


利用shell查看输入的数据

使用书上的例子:

进入shell python manage.py shell

from learning_logs.models import Topic

获取模型Topic的所有实例

Topic.objects.all()

打印每个对象的ID

topics = Topic.objects.all()

for topic in topics: print(topic.id, topic)

于是就能通过ID来查看对象的属性了

t = Topic.objects.get(id=1)

属性: t.text

t.date_added

另一个模型Entry有个属性是topic是它的ForeignKey,可以通过这种关联获取数据

t.entry_set.all()

其中entry是相关模型的小写名称,可以返回出与t相关的Entry的所有对象条目


创建一个主页

​ 分为三个阶段:定义URL、编写视图和编写模板

​ 每个URL对应特定的视图,视图调用一个模板,浏览器通过模板生成网页.

定义URL

在urls.py中的urlpatterns中添加相应的url。

书上的代码是:

在learning_log/urls.py中加入:
url(r'', include('learning_logs.urls', namespace='learning_logs'))
目的是让learning_logs的URL同项目中的其他URL区分开。 然后在learning_logs中创建另一个urls.py文件,引入views
from . import views
其中的urlpatterns中加入
url(r'^$', views.index, name='index')

我的django版本与书上不同,没有url(),只有path()。

我的代码是:

在learning_log/urls.py中
path('', include('learning_logs.urls')), 在learning_logs/urls.py中
path('', views.index, name='index'), ------------------
并且要在此文件中声明:
app_name = 'learning_logs'
(这里我没有仔细看,只是好像不加会报错)

编写视图

views.py中,render()作用是根据提供的数据渲染响应。

书上为主页编写了视图

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

编写模板

在learning_logs中新建一个文件夹,并将其命名为templates。在文件夹templates中,再新建一个文件夹,命名为learning_logs。这是Django能明确解读的结构。

在最里面的文件夹learning_logs中,建立index.html

书上的代码是:

<p>Learning Log</p>

<p>Learning Log helps you keep track of your learning, for any topic you're learning about.</p>

创建其他网页

这个部分书上的代码都跑不通,就把自己修改后的代码写上来。

父模板

先创建一个父模板base.html,项目中其他模板继承它。

<p>
<a href="{% url 'learning_logs:index' %}">Learning Log</a>
<a href="{% url 'learning_logs:topics' %}">Topics</a>
</p> {% block content %}{% endblock content %}

子模板

重新编写index.html使其继承base.html

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

{% block content %}
<p>Learning Log helps you keep track of your learning, for any topic you're learning about.</p>
{% endblock content %}

其中,不是从父模板继承的内容都包含在content块中


显示所有主题(Topics)的页面

定义所有主题页面的URL

修改learning_logs/urls.py,urlpatterns中加上:

path('topics/', views.topics, name='topics'),

视图

修改views.py,加上这段代码

def topics(request):
_topics = Topic.objects.order_by('date_added')
context = {'topics': _topics}
return render(request, './learning_logs/topics.html', context)

context是要发给模板的上下文,是一个字典,键是在模板中要访问数据的名称,值是要发送给模板的数据。

模板

创建topics.html

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

{% block content %}

  <p>Topics</p>

  <ul>
{% for topic in topics %}
<li>{{topic}}</li>
{% empty %}
<li>No topics have been added yet.</li>
{% endfor %}
</ul> {% endblock content %}

修改父模板,使其包含到所有这些页面的链接,改成这样

<p>
<a href="{% url 'learning_logs:index' %}">Learning Log</a> -
<a href="{% url 'learning_logs:topics' %}">Topics</a>
</p> {% block content %}{% endblock content %}

显示特定主题(Topic)的页面

与上面的做法都类似:URL/视图/模板。

URL

在learning_logs/urls.py中,加入

path('topics/<int:topic_id>', views.topic, name='topic')

视图

views.py中,加入

def topic(request, topic_id):
_topic = Topic.objects.get(id=topic_id)
entries = _topic.entry_set.order_by('-date_added')
context = {'topic': topic, 'entries': entries}
return render(request, 'learning_logs/topic.html', context)

date_added前面的减号指定按降序排列。即先显示最近的条目,把主题和条目存进context中,再发送给topic.html

模板

新建topic.html

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

{% block content %}
<p>Topic: {{topic}}</p>
<p>Entries:</p>
<ul>
{% for entry in entries %}
<li>
<p>{{entry.date_added|date:'M d, Y H:i'}}</p>
<p>{{entry.text|linebreaks}}</p> </li>
{% empty %}
<li>No entry for this topic yet.</li>
{% endfor %}
</ul> {% endblock content %}

“|”表示模板过滤器,即这个后面是对模板变量修改的函数。

这里date中,M是month,d是day.........于是显示出来的就是这样:Jul 25, 2022 08:15

linebreaks将包含换行符的长条目转换为浏览器能够理解的格式,以免显示为一个不间断的文本块。

将这些topic的页面设置为链接

修改topics.html,让每个topic都链接到对应网页。改成酱紫:

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

{% block content %}

<p>Topics</p>

<ul>
{% for topic in topics %}
<li>
<a href="{% url 'learning_logs:topic' topic.id %}">{{topic}}</a>
</li>
{% endfor %}
</ul> {% endblock content %}

贴几张到此为止的网页截图:

《Python编程:从入门到实践》第十八章笔记:Django最基本用法笔记的更多相关文章

  1. Python编程从入门到实践笔记——异常和存储数据

    Python编程从入门到实践笔记——异常和存储数据 #coding=gbk #Python编程从入门到实践笔记——异常和存储数据 #10.3异常 #Python使用被称为异常的特殊对象来管理程序执行期 ...

  2. Python编程从入门到实践笔记——文件

    Python编程从入门到实践笔记——文件 #coding=gbk #Python编程从入门到实践笔记——文件 #10.1从文件中读取数据 #1.读取整个文件 file_name = 'pi_digit ...

  3. Python编程从入门到实践笔记——类

    Python编程从入门到实践笔记——类 #coding=gbk #Python编程从入门到实践笔记——类 #9.1创建和使用类 #1.创建Dog类 class Dog():#类名首字母大写 " ...

  4. Python编程从入门到实践笔记——函数

    Python编程从入门到实践笔记——函数 #coding=gbk #Python编程从入门到实践笔记——函数 #8.1定义函数 def 函数名(形参): # [缩进]注释+函数体 #1.向函数传递信息 ...

  5. Python编程从入门到实践笔记——用户输入和while循环

    Python编程从入门到实践笔记——用户输入和while循环 #coding=utf-8 #函数input()让程序暂停运行,等待用户输入一些文本.得到用户的输入以后将其存储在一个变量中,方便后续使用 ...

  6. Python编程从入门到实践笔记——字典

    Python编程从入门到实践笔记——字典 #coding=utf-8 #字典--放在{}中的键值对:跟json很像 #键和值之间用:分隔:键值对之间用,分隔 alien_0 = {'color':'g ...

  7. Python编程从入门到实践笔记——if语句

    Python编程从入门到实践笔记——if语句 #coding=utf-8 cars=['bwm','audi','toyota','subaru','maserati'] bicycles = [&q ...

  8. Python编程从入门到实践笔记——操作列表

    Python编程从入门到实践笔记——操作列表 #coding=utf-8 magicians = ['alice','david','carolina'] #遍历整个列表 for magician i ...

  9. Python编程从入门到实践笔记——列表简介

    Python编程从入门到实践笔记——列表简介 #coding=utf-8 #列表——我的理解等于C语言和Java中的数组 bicycles = ["trek","cann ...

  10. Python编程从入门到实践笔记——变量和简单数据类型

    Python编程从入门到实践笔记——变量和简单数据类型 #coding=gbk #变量 message_1 = 'aAa fff' message_2 = 'hart' message_3 = &qu ...

随机推荐

  1. springcloud + nacos实现共用基础服务(灰度版本)

    背景: 当我们使用微服务时,若想在本地联调就需要启动多个服务,为了避免本地启动过多服务,现将注册中心等基础服务共用.当我们在服务A开发时,都是注册到同一个nacos,这样本地和开发环境的服务A就会同时 ...

  2. js--promise、async 和 await 相关知识总结

    前言 promise 是前端开发人员必须掌握的知识点,本文来总结一下相关学习笔记. 正文 1.什么是prommise,promise 解决了什么问题 a.promise 是什么 Promise 是承诺 ...

  3. 好客租房21-react组件的两种创建方式(函数组件)

    1使用函数创建组件 函数组件:使用js的函数或者箭头函数创建的组件 约定1:函数组件名称必须以 开头 约定2:函数组件必须有返回值 表示该组件的结构 如果返回值为null 表示不渲染任何内容 2.1使 ...

  4. unity---点击事件

    点击事件 点击触发的事件脚本 脚本挂载方式 On Click() 如果点击后触发,调用Button物体下,Button_lick脚本中的func函数/func_text 结果

  5. 122_Power Pivot&Power BI不连续日期的日环比

    博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 这两天有朋友在交流,dax中使用时间智能函数写日环比,一个 dateadd 就可以了.但是有些业务不是每天都连续 ...

  6. Spring 源码(17)Spring Bean的创建过程(8)Bean的初始化

    知识回顾 Bean的创建过程会经历getBean,doGetBean,createBean,doCreateBean,然后Bean的创建又会经历实例化,属性填充,初始化. 在实例化createInst ...

  7. GO的日志库log竟然这么简单!

    前言 最近在尝试阅读字节开源RPC框架Kitex的源码,看到日志库klog部分,果不其然在Go原生的log库的基础上增加了自己的设计,大体包括增加了一些格式化的输出.增加一些常用的日志级别等. 一番了 ...

  8. .NET性能优化-推荐使用Collections.Pooled(补充)

    简介 在上一篇.NET性能优化-推荐使用Collections.Pooled一文中,提到了使用Pooled类型的各种好处,但是在群里也有小伙伴讨论了很多,提出了很多使用上的疑问. 所以特此写了这篇文章 ...

  9. Python装饰器Decorators

    def hi(name="yasoob"): return "hi " + name print(hi()) # 我们甚至可以将一个函数赋值给一个变量,比如 g ...

  10. Docker容器编译安装Redis

    Docker容器编译安装Redis 1.创建容器 -i 交互模式 -d 后端运行 -h 容器的hostname --name 容器名 --network 网卡 --ip IP地址 -p 端口映射 -- ...