前言

除了手动添加你的文章后外,你还可以用命令行来添加,python 自带了一种命令行 就是 shell

快速添加博文:Shell命令行模式

在你的目录下:mysite

python manage.py shell

导入Blog模型:

>>> from blog.models import Blog

验证是否成功引用:

>>> dir()

查看所有博文:

>>> Blog.objects.all()

查看博文数量:

>>> Blog.objects.count()

模型新增对象

实例化对象:

>>> blog = Blog()

查看是否成功:

>>> dir()

因为库中没有,所以库中查不到:

>>> Blog.objects.all()

添加文章标题:

>>> blog.title = "shell下第一篇"

添加文章内容:

>>> blog.context = "xxxxxxxxxxxxxx"

引入BlogType:

>>> from blog.models import BlogType

查询所有BlogType:

>>> BlogType.objects.all()

添加文章类型:

>>> blog.blog_type = BlogType.objects.all()[0]

引入Django的User模型:

>>> from django.contrib.auth.models import User

添加作者:

>>> blog.author = User.objects.all()[0]

保存入库:

>>> blog.save()

查询最新修改时间:

>>> blog.last_updated_time

如果这样一篇一篇当然麻烦,就可以用for 循环来添加

添加大量文章:

>>> for i in range(1, 31):
... blog = Blog()
... blog.title = "for %s" % i
... blog.content = "xxxx: %s" % i
... blog.blog_type = BlogType.objects.all()[0]
... blog.author = User.objects.all()[0]
... blog.save()

记住上面。。。 后面必须要空格

查看是否成功新增:

>>> Blog.objects.all().count()

引入分页器

你的文章过多的话,还是需要分页的,python 自带一个软件

>>> from django.core.paginator import Paginator

查看是否成功引入:

>>> dir()

有些不需要的可以移除,比如:

>>> del Blog

因为后面需要用分类页码来分页

这里最好重新开始 退出

>>> exit()

实例化分页器:

>>> paginator = Paginator(blogs, 10) # 第一个参数是具体的对象列表,第二个参数是每页文章数

模型有默认的排序,但不知道是不是每页的内容不一样,即第一篇博文可能在这一页出现,同时在另一页也出现。所以,最好有个排序规则。按照这个排序规则分页。

然后在你的 blog/models 下修改

...
class Blog(models.Model):
title = models.CharField(max_length=50)
blog_type = models.ForeignKey(BlogType, on_delete=models.DO_NOTHING)
content = models.TextField()
author = models.ForeignKey(User, on_delete=models.DO_NOTHING)
created_time = models.DateTimeField(auto_now_add=True)
last_updated_time = models.DateTimeField(auto_now=True) def __str__(self):
return "<Blog: %s>" % self.title class Meta:
ordering = ['-created_time'] # 按照created_time倒序排序

然后重新 数据库和更新

$ python manage.py makemigrations
$ python manage.py migrate

重新打开shell,引入需要的包(Blog、Paginator),再次实例化分页器:

 >>>  paginator = Paginator(blogs, 10)

可以打印出paginator:

 >>> paginator

查看pagnitor有什么属性和方法:

 >>> dir(paginator)

查看有多少篇文章:

 >>> paginator.count

查看页码:

 >>> paginator.page_range

取第一页:

 >>> page1 = paginator.page(1)

分页的使用

过GET方法获取请求参数,例如: http://127.0.0.1:8000/blog/?page=2 
修改blog/views.py:

from django.shortcuts import render_to_response, get_object_or_404
from django.core.paginator import Paginator
from .models import Blog, BlogType def blog_list(request): blogs_all_list = Blog.objects.all()
paginator = Paginator(blogs_all_list, 10)
page_num = request.GET.get('page', 1) # 获取url的页码参数。GET返回字典,page_num默认为1
page_of_blogs = paginator.get_page(page_num) context = {}
context['page_of_blogs'] = page_of_blogs
# context['blogs_count'] = Blog.objects.all().count()
context['blog_types'] = BlogType.objects.all()
return render_to_response('blog/blog_list.html', context)
...

修改blog/templates/blog/blog_list.html:

{% extends 'base.html' %}

{% block title %}
我的网站
{% endblock %} {% block nav_blog_active %}
active
{% endblock %} {% load staticfiles %}
{% block header_extends %}
<link rel="stylesheet" href="{% static 'blog/blog.css' %}">
{% endblock %} {% block content %}
<div class="container">
<div class="row">
<div class="col-xs-12 col-sm-8 col-md-9 col-lg-10">
<div class="panel panel-default">
<div class="panel-heading">{% block blog_list_title %}博客列表(一共有{{ page_of_blogs.paginator.count }} 篇博文){% endblock %}</div>
<div class="panel-body">
{% for blog in page_of_blogs.object_list %}
<div class="blog">
<h3></h3><a href="{% url 'blog_detail' blog.pk %}">{{ blog.title }}</a></h3>
<p class="blog-info">
<span class="glyphicon glyphicon-tag"></span><a href="{% url 'blogs_with_type' blog.blog_type.pk %}">{{ blog.blog_type }}</a>
<span class="glyphicon glyphicon-time"></span>{{ blog.created_time|date:"Y-m-d" }}
</p>
<p>{{ blog.context|truncatechars:120 }}</p>
</div>
{% empty %}
<div class="blog">
<h3>---暂无博文,敬请期待---</h3>
</div>
{% endfor %}
</div>
</div>
</div>
<div class="hidden-xs col-sm-4 col-md-3 col-lg-2">
<div class="panel panel-default">
<div class="panel-heading">博客分类</div>
<div class="panel-body">
<ul class="blog-types">
{% for blog_type in blog_types %}
<li>
<a href="{% url 'blogs_with_type' blog_type.pk %}">{{ blog_type.type_name }}</a>
</li>
{% empty %}
<li>暂无分类</li>
{% endfor %}
</ul>
</div>
</div>
</div>
</div>
<div>
<ul class="pagination">
<li>
{# 上一页 #}
{% if page_of_blogs.has_previous %}
<a href="?page={{ page_of_blogs.previous_page_number }}" aria-label="Previous">
<span aria-hidden="true">&laquo;</span>
</a>
{% else %}
<span aria-hidden="true">&laquo;</span>
{% endif %}
</li>
<li>
{# 页码 #}
{% for page_num in page_of_blogs.paginator.page_range %}
<a href="?page={{ page_num }}">{{ page_num }}</a>
{% endfor %}
</li>
<li>
{# 下一页 #}
{% if page_of_blogs.has_next %}
<a href="?page={{ page_of_blogs.next_page_number }}" aria-label="Next">
<span aria-hidden="true">&raquo;</span>
</a>
{% else %}
<span aria-hidden="true">&raquo;</span>
{% endif %}
</li>
</ul>
</div>
</div>
{% endblock %}

然后 运行虚拟环境p

python manage.py runserver

就可以看到咯

Python 分页和shell命令行模式的更多相关文章

  1. 使用github的使用,利用git shell命令行模式进行操作

    一.登录到git,新建一个版本仓库 二.在"Repository name"一栏里填写版本仓库的名称,如"test",Description栏是描述,可填可不填 ...

  2. python中执行shell命令行read结果

    +++++++++++++++++++++++++++++ python执行shell命令1 os.system 可以返回运行shell命令状态,同时会在终端输出运行结果 例如 ipython中运行如 ...

  3. python如何在shell命令行执行创建用户命令

  4. 如何在命令行模式下查看Python帮助文档---dir、help、__doc__

    如何在命令行模式下查看Python帮助文档---dir.help.__doc__ 1.dir函数式可以查看对象的属性,使用方法很简单,举str类型为例,在Python命令窗口输入 dir(str) 即 ...

  5. windows命令行模式下无法打开python程序解决方法

    今天刚开始学Python,首先编写一个简单地hello world程序,想在命令行模式运行,结果出现下面: 经过一番思考,发现用cd命令可以解决这件事,看下图: 这样就解决了.

  6. 区分命令行模式和Python交互模式

    命令行模式 在Windows开始菜单选择"命令提示符",就进入到命令行模式,它的提示符类似C:\> Python交互模式 在命令行模式下敲命令python,就看到类似如下的一 ...

  7. centos6.5 python命令行模式左右建无法使用

    我的虚拟机是centos6.5,自带python2.6:安装了Python2.7(安装了pip管理工具)后,在python2.7命令行模式下,左右键及退格键无法使用,基于以上情况,我进行了百度: 第一 ...

  8. 命令行模式和python交互模式

    一.命令行模式 在Windows开始菜单选择“命令提示符”,就进入到命令行模式,它的提示符类似C:>:. 二.Python交互模式 在命令行模式下敲命令python,就看到类似如下的一堆文本输出 ...

  9. mysq在命令行模式下执行shell命令

    mysql可以在命令行模式下执行shell命令 mysql> help For information about MySQL products and services, visit: htt ...

随机推荐

  1. 【DVWA】SQL Injection(SQL 注入)通关教程

    日期:2019-07-28 20:43:48 更新: 作者:Bay0net 介绍: 0x00.基本信息 关于 mysql 相关的注入,传送门. SQL 注入漏洞之 mysql - Bay0net - ...

  2. sql 查询某一列最大的数据

    select colm1,Max(colm2),max(colm3) from table where condition group by colm1

  3. python3.5 append使用

    1.从元组中添加 friends=[] tup1=("Jon",35) friends.append(tup1[0]) print(friends[0]) ssh://root@1 ...

  4. 项目连接oracle报错:listener does not currently know of SID given in connect descriptor

    今天练习用IDEA搭建了一个ssm框架,数据库是oracle,在执行mybatis-generator时,一直报错listener does not currently know of SID giv ...

  5. docker面试总结

    1.什么是docker Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化.容 ...

  6. 意想不到的JavaScript(每日一题2)

    问题一: 答案: 解析:

  7. magento form.html不显示 window 和 Linux下的区别

    window 无大小写区别,所以可以显示表框 Linux 大小写敏感,显示不了 \app\code\community\Company\BabyPay\Model\Payment.php 里定义了fo ...

  8. IntelliJ IDEA将导入的项目转成maven项目

    今天导入公司的maven项目,发现结构不对劲,难怪说为啥一直不能部署tomcat,后面百度才了解到导入这个项目还不是maven项目,首先需要把这个项目变成maven项目,然后再进行tomcat的部署下 ...

  9. Virtual DOM和snabbdom.js

    Virtual DOM和snabbdom.js:https://www.jianshu.com/p/1f1ef915e83e

  10. HDU 1159 Common Subsequence 最长公共子序列

    HDU 1159 Common Subsequence 最长公共子序列 题意 给你两个字符串,求出这两个字符串的最长公共子序列,这里的子序列不一定是连续的,只要满足前后关系就可以. 解题思路 这个当然 ...