利用python對(duì)mysql表做全局模糊搜索并分頁(yè)實(shí)例
在寫(xiě)django項(xiàng)目的時(shí)候,有的數(shù)據(jù)沒(méi)有使用模型管理(數(shù)據(jù)表是動(dòng)態(tài)添加的),所以要直接使用mysql。前端請(qǐng)求數(shù)據(jù)的時(shí)候可能會(huì)指定這幾個(gè)參數(shù):要請(qǐng)求的頁(yè)號(hào),頁(yè)大小,以及檢索條件。
""" tableName: 表名 pageNum: 請(qǐng)求的頁(yè)的編號(hào) pageSize: 每一頁(yè)的大小 searchInfo: 需要全局查詢(xún)的信息 """ def getMysqlData(tableName, pageNum, pageSize, searchInfo): # 使用MySQLdb獲取的mysql游標(biāo) cursor = getCursor() # 用以獲取列標(biāo)題 colSql = 'select * from {} limit 1'.format(tableName) cursor.execute(colSql) columns = [col[0] for col in cursor.description] # 轉(zhuǎn)化查詢(xún)信息為sql searchCondition = ','.join(columns) searchInfo = "WHERE CONCAT({}) like '%{}%'".format(searchCondition, searchInfo) # 用以獲取總數(shù) totalSql = "select count(*) from {} {};".format(tableName, searchInfo) cursor.execute(totalSql) total = cursor.fetchone()[0] # 用以獲取具體數(shù)據(jù) limit1 = (pageNum - 1) * pageSize limit2 = pageSize dataSql = "select * from {} {} limit {},{};".format(tableName, searchInfo, limit1, limit2) cursor.execute(dataSql) data = [ dict(zip(columns, row)) for row in cursor.fetchall() ] return (total, columns, data) """ total: 符合條件的數(shù)據(jù)總數(shù) columns: 字段名列表 ['字段名1', '字段名2', ...] data: 數(shù)據(jù)對(duì)象列表 [{'字段名1': 數(shù)據(jù)1,'字段名2':數(shù)據(jù)1, ...},{'字段名1': 數(shù)據(jù)2, '字段名2': 數(shù)據(jù)2, ...}, ...] """
補(bǔ)充知識(shí):django 分頁(yè)查詢(xún)搜索--傳遞查詢(xún)參數(shù),翻頁(yè)時(shí)帶上查詢(xún)參數(shù)
django在分頁(yè)查詢(xún)的時(shí)候,翻頁(yè)時(shí),v層要傳遞查詢(xún)參數(shù),相應(yīng)的html翻頁(yè)連接也要帶上查詢(xún)參數(shù)
直接上代碼
view:
@login_required def search_name(request): username = request.session.get('user') search_name = request.GET.get('name') if search_name == None: search_name = request.GET.get('name') event_list = Event.objects.filter(name__contains=search_name) paginator = Paginator(event_list, 2) page = request.GET.get('page') try: contacts = paginator.page(page) except PageNotAnInteger: # 如果page不是整數(shù),取第一頁(yè)面數(shù)據(jù) contacts = paginator.page(1) except EmptyPage: # 如果page不在范圍內(nèi),則返回最后一頁(yè)數(shù)據(jù) contacts = paginator.page(paginator.num_pages) return render(request,'event_manage.html',{'user':username,'events':contacts,'name':search_name})
html:
<!--列表分頁(yè)器--> <div class="pagination"> <span class="step-links"> {% if events.has_previous %} <a href="?page={{ events.previous_page_number }}&&name={{ name }}" rel="external nofollow" >previous</a> {% endif %} <span class="current"> Page {{ events.number }} of {{ events.paginator.num_pages }} </span> {% if events.has_next %} <a href="?page={{ events.next_page_number }}&name={{ name }}" rel="external nofollow" >next</a> {% endif %} </span> </div> {% include 'include/pager.html' %}
以上這篇利用python對(duì)mysql表做全局模糊搜索并分頁(yè)實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- python+selenium對(duì)table表和分頁(yè)處理
- Python優(yōu)化列表接口進(jìn)行分頁(yè)示例實(shí)現(xiàn)
- python中Tkinter實(shí)現(xiàn)分頁(yè)標(biāo)簽的示例代碼
- 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)文章
想學(xué)畫(huà)畫(huà)?python滿足你!
這篇文章主要介紹了如何利用python畫(huà)畫(huà),幫助大家更好的理解和使用python的turtle庫(kù),感興趣的朋友可以了解下2020-12-12python中可以發(fā)生異常自動(dòng)重試庫(kù)retrying
這篇文章主要介紹了python中可以發(fā)生異常自動(dòng)重試庫(kù)retrying,retrying是一個(gè)極簡(jiǎn)的使用Python編寫(xiě)的庫(kù),主題更多相關(guān)內(nèi)容需要的朋友可以參考一下2022-06-06PyQt5執(zhí)行耗時(shí)操作導(dǎo)致界面卡死或未響應(yīng)的原因及解決辦法
這篇文章主要給大家介紹了關(guān)于PyQt5執(zhí)行耗時(shí)操作導(dǎo)致界面卡死或未響應(yīng)的原因及解決辦法,由于耗時(shí)的操作會(huì)獨(dú)占系統(tǒng)cpu資源,讓界面卡死在那里,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12python2.7實(shí)現(xiàn)郵件發(fā)送功能
這篇文章主要為大家詳細(xì)介紹了python2.7實(shí)現(xiàn)郵件發(fā)送功能包,含文本、附件、正文圖片等,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12Python+selenium實(shí)現(xiàn)趣頭條的視頻自動(dòng)上傳與發(fā)布
本文主要介紹了通過(guò)Python+selenium實(shí)現(xiàn)趣頭條的短視頻自動(dòng)上傳與發(fā)布功能,同時(shí)支持抖音、快手、b站、小紅書(shū)等平臺(tái)的視頻自動(dòng)化同步發(fā)布。需要的朋友可以參考一下2021-12-12Python實(shí)現(xiàn)二值掩膜影像去噪與邊緣強(qiáng)化方法詳解
這篇文章主要介紹了Python實(shí)現(xiàn)二值掩膜影像去噪與邊緣強(qiáng)化方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-01-01python使用tesseract實(shí)現(xiàn)字符識(shí)別功能
Tesseract 是一個(gè)開(kāi)源的光學(xué)字符識(shí)別(OCR)引擎,它能夠識(shí)別多種語(yǔ)言的文本,可將掃描文檔、圖像中的文字提取并轉(zhuǎn)換為計(jì)算機(jī)可編輯的文本格式,本文給大家介紹了python使用tesseract實(shí)現(xiàn)字符識(shí)別功能,需要的朋友可以參考下2024-10-10tensorflow實(shí)現(xiàn)對(duì)張量數(shù)據(jù)的切片操作方式
今天小編就為大家分享一篇tensorflow實(shí)現(xiàn)對(duì)張量數(shù)據(jù)的切片操作方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01Pandas時(shí)間序列基礎(chǔ)詳解(轉(zhuǎn)換,索引,切片)
今天小編就為大家分享一篇Pandas時(shí)間序列基礎(chǔ)詳解(轉(zhuǎn)換,索引,切片),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02