Python如何優化列表介面進行分頁
導讀 | 最近,在做測試開發平臺的時候,需要對測試用例的列表進行後端分頁,在實際去寫程式碼和測試的過程中,發現這裡面還是有些細節的,故想覆盤一下 |
做個假設,加入用例庫有 1W 條資料,如果想要以列表形式展示,一次性返回 1W 條資料;
這樣做有兩個弊端:
1.這樣寫出來的介面會慢。想一下如果隨著時間的發展,這個數量變成了 10W、100W 該怎麼辦?
2.對前端不友好。用前端渲染 1W 條資料,有理智的開發都不會這麼做。
所以,我們做分頁的目的,主要是為了效能的提高,提高使用體驗。
我這邊開發語言是Python,Web框架用的是 Tornado,後臺資料庫用的是 Mongodb。
首先,我們做一下介面的設計,如下:
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 } }
返回資料結構解析:
- cases 的值是包含多個 case 物件的列表;
- count 指的是 case 的總數,這樣前端就可以通過 count 來判斷一共有多少頁,然後通過點選的頁數直接請求到對應頁的資料做展示,這樣做可以有效的控制返回的資料量以及返回時間,提高使用者體驗感。
根據上述的介面約定,介面實現如下(僅展示關鍵程式碼):
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_={}) }
下面我們逐行來解讀這個介面。
1.根據 API 約定,page和limit是不必傳且有預設值,所以獲取時可以直接寫為self.input.page or 1,其中當page不傳時self.input.page為None。
2.後端獲取到的GET請求的請求引數是String,所以需要int()轉為整型,這裡直接int(page)即可,因為經過了前面的處理,page必然是有值的。
3.通過limit * (page - 1),計算出跳過多少個;白話描述skip的作用就是,從第skip個物件開始,往後取limit個,返回。
4.get_case_list方法和get_count方法的filter_引數的值應該保持一致,因為他們都是對case這個物件做操作,只不過count是取總數而已。
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.對skip和limit的空值判斷要用is not None,因為skip可能為,如果使用if skip來判斷,skip=0的時候也會進入分支。
2.sort = [(‘create_time', -1)]的傳入使返回的列表按照建立時間倒敘排列,如果你不做這個,相信負責人的測試同學會給你提一個“易用性問題”。
3.sort + skip + limit是有執行優先順序的,他們優先順序依次是sort→skip→limit,skip+limit的優先順序為skip→limit。
這裡大家不要去考慮pymogo執行的時候會不會對sort、skip、limit自動給按照優先順序執行,傳參的時候按照優先順序去傳參就好了,養成良好的習慣,不必糾結其他的。
async def get_count(cls, filter_: dict) -> int: """ 獲取 case 總數 """ return await ModelHandler.count('case', filter=filter_)
這裡用count來獲取資料,可以直接拿到總數,而不是取出list然後去求length,避免了記憶體空間的浪費。
以上,就是對列表介面進行分頁的整個過程啦,謝謝閱讀,這不是一篇餵飯教程,是帶你熟悉了寫這個介面的整個過程及其中的細節,具體的實現還需要大家動手去實踐。
原文來自:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2795241/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 如何進行頁面優化?優化
- 分庫分表如何進行極致的優化優化
- 如何在Python中對dicts列表進行排序Python排序
- 如何使用python進行網頁爬取?Python網頁
- 分頁查詢優化優化
- 面試題——Mybatis是如何進行分頁的面試題MyBatis
- MySQL分頁查詢優化MySql優化
- python:利用iloc語句對列表的分類變數進行操作Python變數
- 億萬級分庫分表後如何進行跨表分頁查詢
- 記一次分頁優化優化
- Node效能如何進行監控以及優化?優化
- 如何進行 Linux 啟動時間優化Linux優化
- 如何使用 Python 進行字串格式化Python字串格式化
- Web 頁面優化專項 > Lighthouse > 效能分數優化Web優化
- SpringBoot介面 - 如何優雅的對引數進行校驗?Spring Boot
- Java -- 對List集合進行分頁Java
- MySQL分優化之超大頁查詢MySql優化
- Oracle優化案例-單表分頁語句的優化(八)Oracle優化
- SQL優化案例-單表分頁語句的優化(八)SQL優化
- Web頁面如何進行視覺化埋點(二)Web視覺化
- Web頁面如何進行視覺化埋點(一)Web視覺化
- Web頁面如何進行視覺化埋點(三)Web視覺化
- 如何使用Python 進行資料視覺化Python視覺化
- python執行麟遊介面自動化--什麼是介面、介面優勢、型別(詳解)Python型別
- Python + requests + unittest + ddt 進行介面自動化測試的框架Python框架
- charles 如何進行介面測試?
- Python+django網頁設計入門(16):優化設計複用分頁程式碼PythonDjango網頁優化
- 在React專案中,如何優雅的優化長列表React優化
- 站群網站如何進行百度優化網站優化
- mysql查詢太慢,我們如何進行效能優化?MySql優化
- 一次簡單的分頁優化優化
- 使用shouldComponentUpdate進行效能優化優化
- Vue進階系列 --- 頁面架構優化Vue架構優化
- SAP UI5 列表控制元件分頁顯示資料時,如何自定義分頁大小UI控制元件
- 如何優雅地實現分頁查詢
- Postman 如何進行 Websocket 介面測試PostmanWeb
- Flutter中如何進行介面跳轉Flutter
- 使用Shader進行UGUI的優化UGUI優化