首页 > 其他分享 >分页:pagination.py

分页:pagination.py

时间:2023-11-06 21:00:05浏览次数:31  
标签:count pagination 分页 self py param dict query page

'''
一、在视图函数中:
	def pretty_list(request):
		# 0.搜索数据
		data_dict = {}
		search_data = request.GET.get('q', '')
		if search_data:
			data_dict['mobile__contains'] = search_data
		# 1.根据情况筛选数据
		queryset = models.PrettyNum.objects.filter(**data_dict).order_by('-id')
		# 2.实例化分页对象
		page_object = Pagination(request, queryset,page_size=20)
		context = {
			'search_data': search_data,
			'queryset': page_object.page_queryset,  # 分完页的数据
			'page_string': page_object.html()  # 页码
		}
		return render(request, 'pretty_list.html', context)
二、在HTML中:
	<ul class="pagination">
		{{ page_string }}
	</ul>
'''
from django.utils.safestring import mark_safe

class Pagination(object):
	    def __init__(self, request, queryset, page_size=10, page_param='page', plus=5):
    '''
    :param request: 请求的对象
    :param queryset: 符合条件的数据,根据他进行分页
    :param page_size:每页显示多少条数据
    :param page_param:在URL中传递的分页的参数:/pretty/list/?page=page_param
    :param plus:显示当前面的前后几页。
    '''
    # 保存搜索条件
    import copy
    query_dict = copy.deepcopy(request.GET)
    query_dict._mutable = True
    self.query_dict = query_dict
    self.page_param = page_param

    page = request.GET.get(page_param, '1')
    if page.isdecimal():
        page = int(page)
    else:
        page = 1
    self.page = page
    self.page_size = page_size
    self.start = (page - 1) * page_size
    self.end = page * page_size

    self.page_queryset = queryset[self.start:self.end]

    # 数据库的总条数
    total_count = queryset.count()

    # 总页码
    total_page_count, div = divmod(total_count, page_size)
    if div:
        total_page_count += 1
    self.total_page_count = total_page_count
    self.plus = plus

	def html(self):
		# 计算出,显示当前页的前5页、后5页
		if self.total_page_count <= 2 * self.plus + 1:
			# 数据库中的数据比较少,都没有达到11页,
			start_page = 1
			end_page = self.total_page_count
		else:
			# 数据库中的数据比较多,大于11页

			# 当前页<5时
			if self.page <= self.plus:
				start_page = 1
				end_page = 2 * self.plus + 1
			else:
				# 当前>5时:当前页+5>总页面
				if (self.page + self.plus) > self.total_page_count:
					start_page = self.total_page_count - 2 * self.plus
					end_page = self.total_page_count
				else:
					start_page = self.page - self.plus
					end_page = self.page + self.plus

		# 页码
		page_str_list = []

		self.query_dict.setlist(self.page_param, [1])
		page_str_list.append('<li><a href="?{}">首页</a></li>'.format(self.query_dict.urlencode()))

		# 上一页
		if self.page > 1:
			self.query_dict.setlist(self.page_param, [self.page - 1])
			prev = '<li><a href="?{}">上一页</a></li>'.format(self.query_dict.urlencode())
		else:
			self.query_dict.setlist(self.page_param, [1])
			prev = '<li><a href="?{}">上一页</a></li>'.format(self.query_dict.urlencode())
		page_str_list.append(prev)

		for i in range(start_page, end_page + 1):
			self.query_dict.setlist(self.page_param, [i])
			if i == self.page:
				ele = '<li class="active"><a href="?{}">{}</a></li>'.format(self.query_dict.urlencode(), i)
			else:
				ele = '<li><a href="?{}">{}</a></li>'.format(self.query_dict.urlencode(), i)

			page_str_list.append(ele)

		# 下一页
		if self.page < self.total_page_count:
			self.query_dict.setlist(self.page_param, [self.page + 1])
			prev = '<li><a href="?{}">下一页</a></li>'.format(self.query_dict.urlencode())
		else:
			self.query_dict.setlist(self.page_param, [self.total_page_count])
			prev = '<li><a href="?{}">下一页</a></li>'.format(self.query_dict.urlencode())
		page_str_list.append(prev)

		# 尾页
		self.query_dict.setlist(self.page_param, [self.total_page_count])
		page_str_list.append('<li><a href="?{}">尾页</a></li>'.format(self.query_dict.urlencode()))

		search_string = '''
				   <li>
					   <form action="" method="get" style="float:left;margin-left: -1px;">
						   <input name="page"
								  style="position: relative;float: left;display: inline-block;width: 88px;border-radius: 0;"
								  class="form-control" placeholder="页码">
						   <button style="border-radius: 0" class="btn btn-default" type="submit">跳转</button>
					   </form>
				   </li>
			   '''
		page_str_list.append(search_string)

		page_string = mark_safe(''.join(page_str_list))
		return page_string

标签:count,pagination,分页,self,py,param,dict,query,page
From: https://www.cnblogs.com/jyfyb/p/17812833.html

相关文章

  • Python50days
    筛选器方法document.getElementById()-------标签对象-------标签jQuery对象$(document.个体、ElementById())----------jQuery对象----------可以使用jQuery对象提供的方法如何把jQuery对象转为标签对象  $===jQuery$()[0]$("#id")===jQuery("#id") 菜单例子 hide—......
  • `Python 2.x` 与 `3​​.x` 版本简介
    目前市场上有两个Python的版本并存着,分别是Python2.x和Python3.x新的Python程序建议使用Python3.0版本的语法Python2.x是过去的版本解释器名称是pythonPython3.x是现在和未来主流的版本解释器名称是python3相对于Python的早期版本,这是一个较大的升级为了不......
  • Python_Flask视图类和蓝图
    Flask视图类1.设置路由的新方法:将URL路径和一个视图类关联将URL路径和一个函数关联,这个函数又被称为视图函数在Flask中,也可以使用类来处理相关的URL,这样的也被称为视图类。使用类视图的好处是支持继承,可以把一些共性的东西放在父类中,其他子类可以继承###......
  • 如何防止用户阅读Python代码?
    内容来自DOChttps://q.houxu6.top/?s=如何防止用户阅读Python代码?我正在使用Python开发一款软件,该软件将被分发给我雇主的客户。我的雇主希望通过受限时许可证文件来限制软件的使用。如果我们分发.py文件或甚至.pyc文件,那么将很容易(反编译和)删除检查许可证文件的代码。另一......
  • 代码训练营第二十五天(Python)| 216.组合总和III 、17.电话号码的字母组合
    216.组合总和IIIclassSolution:defcombinationSum3(self,k:int,n:int)->List[List[int]]:res=[]self.tracebacking(n,k,1,0,[],res)returnresdeftracebacking(self,targetsum,k,start,now_sum,path,res):......
  • Python如何写注释?
    python如何写给函数写注释:样板:defread_baseline(self,sheet='internal',category='ipe_flip',):"""功能:-从baseline的Excel文件中读取数据。参数:-sheet:要读取的sheet名称,默认为internal-catego......
  • python
    1,pip安装第三方库时报错 CouldnotinstallpackagesduetoanOSError 执行如下 python-mensurepippython-mpipinstall--upgradepip2,pyhton的IDLE编辑使用相对路径, 前面不能包含其他文件名格式: ./目标文件名字。notepad++ 关联python只能用绝对路径......
  • 【Python | 进阶】 各路日常用法技巧,确定不来看看?
    ......
  • pythonDay7
    列表值的追加、插入、删除 列表+count/index/reverse/sort/clear 补充1;队列  补充2:栈区 元组:tuple只能读不能改,就是一个不可变的列表字典的数据类型转换方式 字典删除 字典;clear\update\get\setdefault ......
  • Python工具箱系列(四十五)
    内存映射文件 mmap是python内置标准库,提供将文件映射到内存的机制。通过mmap将文件映射到内存之后,我们可以高效并优雅地对文件的内容进行随机访问。通常打开文件后要通过组合各种seek()、read()和write()调用来访问,使用mmap后可以简单将文件映射到内存,然后通过切片操作来访问数据......