zoukankan      html  css  js  c++  java
  • 分页

    class Pager():
        """
        baseurl: url
        current_page: 当前页码
        data_entry:每页多少条数据
        database_message:{db:'',
        user:'',
        passwd:'',
        host:'',
        }
        """
        def __init__(self,current_page, baseurl, data_entry):
            self.baseurl = baseurl
            self.current_page = current_page
            try:
                self.current_page = int(self.current_page)
            except:
                self.current_page = 1
            if self.current_page < 1:
                self.current_page = 1
    
            conn = pymysql.connect(host='123.206.96.209', port=3306, user='root', passwd='1,Aa13473860551', db='test')
            cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
            # 假设当前页码是第10页
            # current_page = 1
            # 总行数
            cursor.execute('select count(1) as count from opt')
            total_rows = cursor.fetchone()['count']
    
            # 总页数
            total_pages = total_rows // data_entry
            # print(total_rows)
    
            # 当前页最大行号 + 1 (因为下面要使用小于,所以这要 + 1)
            max_line = total_rows - (self.current_page - 1) * data_entry + 1
    
            cursor.execute(
                "select o.id,o.email,o.name,o.time from opt as o inner join (select id from opt where id < %s order by id desc limit %s) as f on f.id=o.id",
                (max_line,data_entry))
            self.current_page_data = cursor.fetchall()
            # print(current_page_data)
            cursor.close()
            conn.close()
    
            if total_pages < 11:
                s = 1
                t = total_pages + 1
            else:
                if self.current_page < 6:
                    s = 1
                    t = 12
                else:
                    if self.current_page + 5 > total_pages:
                        s = self.current_page - 5
                        t = self.current_page + 1
                    else:
                        s = self.current_page - 5
                        t = self.current_page + 6
    
            tag_list = []
            if self.current_page == 1:
                # perv = "<a href='javascript:void(0)'>上一页</a>"
                pass
            else:
                perv = "<a href='/%s/%s'>上一页</a>" % (self.baseurl,(self.current_page - 1),)
                home_page = "<a href='/%s/%s'>首页</a>" % (self.baseurl,1,)
                tag_list.append(perv)
                tag_list.append(home_page)
    
            for i in range(s, t):
                if i == self.current_page:
                    s = "<a class=active href='/%s/%s'>%s</a>" % (self.baseurl,i, i)
                else:
                    s = "<a href='/%s/%s'>%s</a>" % (self.baseurl,i, i)
                tag_list.append(s)
    
            if self.current_page == total_pages:
                 #end_page = "<a href='javascript:void(0)'>末页</a>"
                pass
            else:
                end_page = "<a href='/%s/%s'>末页</a>" % (self.baseurl,total_pages,)
                nex = "<a href='/%s/%s'>下一页</a>" % (self.baseurl, (self.current_page + 1),)
                tag_list.append(end_page)
                tag_list.append(nex)
    
            total_page = "<span>共 %s 页</span>" % (total_pages)
    
            go = """
                    <input type='text'style='35px;height:25px;'/>
                    <a href='javascript:void(0)' onclick="Jump('%s',this);">跳转</a>
                """ % ('/' + self.baseurl + '/')
            jump = '''
                <script>
                    function Jump(baseUrl, ths){
                        var val = ths.previousElementSibling.value;
                        if(val.trim().length >0){
                            location.href = baseUrl +val;
                        }
                    }
                </script>
                '''
    
            tag_list.append(total_page)
            tag_list.append(go)
            tag_list.append(jump)
            self.current_str_page = "".join(tag_list)
    
            # print(current_str_page)
        def returnPage(self):
            return self.current_str_page, self.current_page_data
    

      

    用法:

    class IndexHandler(tornado.web.RequestHandler):
    def get(self, page):
    import time
    a = time.time()
          传入 page :当前页码 url 每页条目数
    pager = Pager(page, 'index',10)
    current_str_page,current_dic = pager.returnPage()
    b = time.time()
    print(b-a)
    self.render('index.html', pager = current_str_page,current_dic = current_dic)
  • 相关阅读:
    [转]NopCommerce MVC 插件机制分析
    压力测试的轻量级具体做法[转载]
    导入IP安全策略图解
    Grunt使用心得
    解决yarn管理资源管理,其他应用起不来
    Spark 读取mysql中的数据
    Spark 配置连接hive 元数据库(mysql)
    Linux安装anaconda和集成PySpark
    python(配置)
    Python 数据爬取(环境变量)
  • 原文地址:https://www.cnblogs.com/yangxiaolan/p/5754163.html
Copyright © 2011-2022 走看看