Python優(yōu)化列表接口進(jìn)行分頁(yè)示例實(shí)現(xiàn)
分頁(yè)的目的
做個(gè)假設(shè),加入用例庫(kù)有 1W 條數(shù)據(jù),如果想要以列表形式展示,一次性返回 1W 條數(shù)據(jù);
這樣做有兩個(gè)弊端:
1.這樣寫出來(lái)的接口會(huì)慢。想一下如果隨著時(shí)間的發(fā)展,這個(gè)數(shù)量變成了 10W、100W 該怎么辦?
2.對(duì)前端不友好。用前端渲染 1W 條數(shù)據(jù),有理智的開(kāi)發(fā)都不會(huì)這么做。
所以,我們做分頁(yè)的目的,主要是為了性能的提高,提高使用體驗(yàn)。
我這邊開(kāi)發(fā)語(yǔ)言是Python,Web框架用的是 Tornado,后臺(tái)數(shù)據(jù)庫(kù)用的是 Mongodb。
接口設(shè)計(jì)
首先,我們做一下接口的設(shè)計(jì),如下:
HTTP URL: /api/admin/v1/case/list HTTP Method: GET Request Params Reponse Data { "code": 0, "message": null, "data": { "cases": [ { "method": str, "url": str, "request_data"?: str, "request_params"?: str, "header": dict, "reponse_data"?: str }, ... ], "count": int } }
返回?cái)?shù)據(jù)結(jié)構(gòu)解析:
- cases 的值是包含多個(gè) case 對(duì)象的列表;
- count 指的是 case 的總數(shù),這樣前端就可以通過(guò) count 來(lái)判斷一共有多少頁(yè),然后通過(guò)點(diǎn)擊的頁(yè)數(shù)直接請(qǐng)求到對(duì)應(yīng)頁(yè)的數(shù)據(jù)做展示,這樣做可以有效的控制返回的數(shù)據(jù)量以及返回時(shí)間,提高用戶體驗(yàn)感。
根據(jù)上述的接口約定,接口實(shí)現(xiàn)如下(僅展示關(guān)鍵代碼):
class CaseList(APIHandler): async def get_handler(self): page = self.input.page or 1 limit = self.input.limit or 12 page, limit = int(page), int(limit) skip = limit * (page - 1) return { 'customers': await CaseService.get_case_list(filter_={}, skip=skip, limit=limit), 'count': await CaseService.get_count(filter_={}) }
接口解讀
下面我們逐行來(lái)解讀這個(gè)接口。
1.根據(jù) API 約定,page和limit是不必傳且有默認(rèn)值,所以獲取時(shí)可以直接寫為self.input.page or 1,其中當(dāng)page不傳時(shí)self.input.page為None。
2.后端獲取到的GET請(qǐng)求的請(qǐng)求參數(shù)是String,所以需要int()轉(zhuǎn)為整型,這里直接int(page)即可,因?yàn)榻?jīng)過(guò)了前面的處理,page必然是有值的。
3.通過(guò)limit * (page - 1),計(jì)算出跳過(guò)多少個(gè);白話描述skip的作用就是,從第skip個(gè)對(duì)象開(kāi)始,往后取limit個(gè),返回。
4.get_case_list方法和get_count方法的filter_參數(shù)的值應(yīng)該保持一致,因?yàn)樗麄兌际菍?duì)case這個(gè)對(duì)象做操作,只不過(guò)count是取總數(shù)而已。
CaseService.get_case_list方法
async def get_case_list(filter_: dict, skip: int = None, limit: int = None) -> Optional[List[dict]]: """ 獲取 case 列表 """ sort = [('create_time', -1)] if skip is not None and limit is not None: ret = await cls.find('case', filter=filter_, sort=sort, limit=limit, skip=skip) else: ret = await cls.find('case', filter=filter_, sort=sort) return ret
1.對(duì)skip和limit的空值判斷要用is not None,因?yàn)閟kip可能為,如果使用if skip來(lái)判斷,skip=0的時(shí)候也會(huì)進(jìn)入分支。
2.sort = [(‘create_time', -1)]的傳入使返回的列表按照創(chuàng)建時(shí)間倒敘排列,如果你不做這個(gè),相信負(fù)責(zé)人的測(cè)試同學(xué)會(huì)給你提一個(gè)“易用性問(wèn)題”。
3.sort + skip + limit是有執(zhí)行優(yōu)先級(jí)的,他們優(yōu)先級(jí)依次是sort→skip→limit,skip+limit的優(yōu)先級(jí)為skip→limit。
這里大家不要去考慮pymogo執(zhí)行的時(shí)候會(huì)不會(huì)對(duì)sort、skip、limit自動(dòng)給按照優(yōu)先級(jí)執(zhí)行,傳參的時(shí)候按照優(yōu)先級(jí)去傳參就好了,養(yǎng)成良好的習(xí)慣,不必糾結(jié)其他的。
CaseService.get_count方法
async def get_count(cls, filter_: dict) -> int: """ 獲取 case 總數(shù) """ return await ModelHandler.count('case', filter=filter_)
這里用count來(lái)獲取數(shù)據(jù),可以直接拿到總數(shù),而不是取出list然后去求length,避免了內(nèi)存空間的浪費(fèi)。
以上,就是對(duì)列表接口進(jìn)行分頁(yè)的整個(gè)過(guò)程啦,謝謝閱讀,這不是一篇喂飯教程,是帶你熟悉了寫這個(gè)接口的整個(gè)過(guò)程及其中的細(xì)節(jié),具體的實(shí)現(xiàn)還需要大家動(dòng)手去實(shí)踐。
以上就是Python優(yōu)化列表接口進(jìn)行分頁(yè)示例實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于Python優(yōu)化的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- python+selenium對(duì)table表和分頁(yè)處理
- python中Tkinter實(shí)現(xiàn)分頁(yè)標(biāo)簽的示例代碼
- 利用python對(duì)mysql表做全局模糊搜索并分頁(yè)實(shí)例
- python Django框架實(shí)現(xiàn)web端分頁(yè)呈現(xiàn)數(shù)據(jù)
- python web框架中實(shí)現(xiàn)原生分頁(yè)
- Python Django實(shí)現(xiàn)layui風(fēng)格+django分頁(yè)功能的例子
- python 實(shí)現(xiàn)分頁(yè)顯示從es中獲取的數(shù)據(jù)方法
- python自定義分頁(yè)器的實(shí)現(xiàn)
相關(guān)文章
python dict 相同key 合并value的實(shí)例
今天小編就為大家分享一篇python dict 相同key 合并value的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01Python?中的嵌套字典推導(dǎo)的使用及優(yōu)勢(shì)
Python 字典推導(dǎo)是一個(gè)強(qiáng)大的工具,允許您從現(xiàn)有的字典創(chuàng)建新的字典,這篇文章主要介紹了Python中的嵌套字典推導(dǎo),將探索 Python 嵌套字典推導(dǎo)、它的使用以及在 Python 中使用它的優(yōu)勢(shì),需要的朋友可以參考下2023-05-05python Dtale庫(kù)交互式數(shù)據(jù)探索分析和可視化界面
這篇文章主要為大家介紹了python Dtale庫(kù)交互式數(shù)據(jù)探索分析和可視化界面實(shí)現(xiàn)功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01Python實(shí)現(xiàn)去除列表中重復(fù)元素的方法總結(jié)【7種方法】
今天小編就為大家分享一篇關(guān)于Python實(shí)現(xiàn)去除列表中重復(fù)元素的方法總結(jié)【7種方法】,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02Python中基本的日期時(shí)間處理的學(xué)習(xí)教程
這篇文章主要介紹了Python中基本的日期時(shí)間處理的學(xué)習(xí)教程,日期時(shí)間相關(guān)模塊的使用是Python入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-10-10400多行Python代碼實(shí)現(xiàn)了一個(gè)FTP服務(wù)器
400多行Python代碼實(shí)現(xiàn)了一個(gè)FTP服務(wù)器,實(shí)現(xiàn)了比之前的xxftp更多更完善的功能2012-05-05使用Python將PDF文件轉(zhuǎn)存為圖片的代碼示例
因工作中的某些奇葩要求,需要將PDF文件的每頁(yè)內(nèi)容轉(zhuǎn)存成按順序編號(hào)的圖片,用第三方軟件或者在線轉(zhuǎn)換也可以,但批量操作還是Python方便,所以本文給大家介紹了使用Python將PDF文件轉(zhuǎn)存為圖片的方法,需要的朋友可以參考下2023-09-09python實(shí)現(xiàn)輸入的數(shù)據(jù)在地圖上生成熱力圖效果
今天小編就為大家分享一篇python實(shí)現(xiàn)輸入的數(shù)據(jù)在地圖上生成熱力圖效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12