python 制作本地應(yīng)用搜索工具
一.準(zhǔn)備工作
請(qǐng)確保已經(jīng)安裝tkinter、pyperclip、threading
二.預(yù)覽
1.啟動(dòng)
這是程序啟動(dòng)的主界面。
2.運(yùn)行
搜索之后的界面。
3.結(jié)果
選擇應(yīng)用,右擊鼠標(biāo)復(fù)制它的下載鏈接。
三.設(shè)計(jì)思路
四.源代碼
本次還是將GUI和搜索引擎分離開來,只要下面兩個(gè)py文件在一個(gè)文件夾,結(jié)合已有的數(shù)據(jù)庫就能實(shí)現(xiàn)上述功能。
4.1 GUI.py
from tkinter import * from tkinter import ttk from tkinter import messagebox from Search_Apps import Find_APP import threading import pyperclip ''' -treeview顯示搜索結(jié)果 -Menu綁定復(fù)制鏈接 ''' class App: def __init__(self): self.w=Tk() self.w.title('應(yīng)用搜索工具(本地版)-v1.0') width=590 height=395 left=(self.w.winfo_screenwidth()-width)/2 top=(self.w.winfo_screenheight()-height)/2 self.w.resizable(0,0) self.w.geometry('%dx%d+%d+%d'%(width,height,left,top)) self.create_widet() self.set_widget() self.place_widget() self.w.mainloop() def create_widet(self): self.l2_var=StringVar() self.l1=ttk.Label(self.w,text='關(guān)鍵字:') self.e1=ttk.Entry(self.w) self.b1=ttk.Button(self.w,text='搜索') self.tree=ttk.Treeview(self.w) self.S_coll_vertical = Scrollbar(self.w, orient=VERTICAL) self.l2=ttk.Label(self.w,textvariable=self.l2_var) self.m=Menu(self.w) self.w['menu']=self.m self.m2=Menu(self.tree,tearoff=False) def set_widget(self): self.b1.config(command=lambda :self.thread_it(self.search_app)) self.e1.config(justify='center') columns=('no','app_name','app_cate','size','app_intro') self.tree.config(show='headings',columns=columns,selectmode=BROWSE,displaycolumns ='#all') self.tree.column("no", anchor="center",minwidth=40,width=40, stretch=NO) self.tree.column("app_name", anchor="center",minwidth=50,width=80, stretch=NO) self.tree.column("app_cate", anchor="center",minwidth=50,width=80, stretch=NO) self.tree.column("size", anchor="center",minwidth=50,width=80, stretch=NO) self.tree.column("app_intro", anchor="center",minwidth=10,width=100) self.tree.heading("no", text="序號(hào)") self.tree.heading("app_name", text="名稱") self.tree.heading("app_cate", text="類別") self.tree.heading("size", text="大小") self.tree.heading("app_intro", text="介紹") self.tree.bind('<<TreeviewSelect>>',self.display_infos) self.S_coll_vertical.config(command=self.tree.yview) self.tree['yscrollcommand'] = self.S_coll_vertical.set self.l2.config(background='lightblue',justify='center') self.l2_var.set('請(qǐng)先搜索') self.s1=Menu(self.m,tearoff=False) self.s2=Menu(self.m,tearoff=False) self.m.add_cascade(label='操作',menu=self.s1) self.m.add_cascade(label='關(guān)于',menu=self.s2) self.s1.add_command(label='搜索',command=lambda :self.thread_it(self.search_app)) self.s1.add_command(label='復(fù)制下載地址',command=lambda:self.thread_it(self.copy_apklink)) self.s1.add_separator() self.s1.add_command(label='退出',command=self.quit_window) self.s2.add_command(label='說明',command=self.show_explain) self.s2.add_command(label='聯(lián)系作者',command=self.show_info) self.w.protocol('WM_DELETE_WINDOW',self.quit_window) self.m2.add_command(label='復(fù)制鏈接',command=self.copy_apklink) self.tree.bind('<Button-3>',self.copy_link) def place_widget(self): self.l1.place(x=70,y=20) self.e1.place(x=150,y=20,width=250) self.b1.place(x=430,y=18) self.tree.place(x=10,y=60,width=570,height=300) self.S_coll_vertical.place(x=570,y=60,height=300) self.l2.place(x=10,y=367,width=570) def search_app(self): #清空treeview數(shù)據(jù) for item in self.tree.get_children(): self.tree.delete(item) key_word=self.e1.get() if key_word: self.l2_var.set(f'正在檢索......') self.data=Find_APP().search_app(key_word) if self.data: i=0 for v in self.data: self.tree.insert('',i,values=(i+1,v.get('app_name'),v.get('app_cate'),v.get('size'),v.get('app_intro'))) i+=1 self.l2.config(background='lightblue') self.l2_var.set(f'一共檢索到[{len(self.data)}]個(gè)關(guān)于[{key_word}]的應(yīng)用') elif self.data is False: self.l2.config(background='red') self.l2_var.set(f'數(shù)據(jù)庫連接失敗,請(qǐng)檢查數(shù)據(jù)庫配置!') else: self.l2.config(background='green') self.l2_var.set(f'沒有檢索到關(guān)于[{key_word}]的應(yīng)用') else: messagebox.showwarning('警告','請(qǐng)輸入關(guān)鍵字!') self.l2.config(background='red') self.l2_var.set(f'請(qǐng)輸入關(guān)鍵字!') def display_infos(self,event): #獲取treeview當(dāng)前選中項(xiàng)數(shù)據(jù) curr=self.tree.item(self.tree.focus()).get('values') #獲取treeview當(dāng)前選中項(xiàng)索引 # curr_index = self.tree.index(self.tree.focus()) # app=self.data[curr_index] self.l2_var.set(f'{curr[-1]}') def show_info(self): messagebox.showinfo('聯(lián)系作者', '作者QQ:xxxx') def show_explain(self): messagebox.showinfo('說明', '\r本軟件僅供學(xué)習(xí),請(qǐng)勿用于商業(yè)用途\n\n1.在輸入框輸入關(guān)鍵字進(jìn)行搜索\n2.選擇應(yīng)用右擊提取下載地址') def copy_link(self,event): self.m2.post(event.x_root, event.y_root) def copy_apklink(self): try: curr_index = self.tree.index(self.tree.focus()) app_link=self.data[curr_index].get('app_link') pyperclip.copy(app_link) messagebox.showinfo('提示','下載地址已成功復(fù)制到剪切板!') except AttributeError: messagebox.showwarning('警告','請(qǐng)先選中應(yīng)用!') self.l2.config(background='red') self.l2_var.set('請(qǐng)先選中應(yīng)用!') def quit_window(self): ret=messagebox.askyesno('退出','是否要退出?') if ret: self.w.destroy() def thread_it(self,func,*args): t=threading.Thread(target=func,args=args) t.setDaemon(True) t.start() if __name__ == '__main__': a=App()
4.2 Search_Apps.py
import pymongo class Find_APP(object): def __init__(self): self.Mongo_host='127.0.0.1' self.Mongo_port=27017 def connect_db(self): try: conn=pymongo.MongoClient(host=self.Mongo_host,port=self.Mongo_port) self.db=conn.HuaWei self.myset=self.db.app_infos return True except: return False "{app_name: {$regex:/keyword/}}"#使用正則mongodb模糊查詢 def search_app(self,key_word): if self.connect_db(): app_data=[] sentence={'app_name': {"$regex":key_word}} try: for i in self.myset.find(sentence): i.pop('_id') app_data.append(i) return app_data except : return False else: return False
五.總結(jié)
本次使用tkinter制作了一款應(yīng)用搜索工具,使用其中的Treeview顯示搜索結(jié)果,使用Menu綁定相關(guān)操作,通過執(zhí)行Mongodb查詢語句得到相關(guān)數(shù)據(jù),所以要結(jié)合本地Mongodb數(shù)據(jù)庫,整體執(zhí)行效率高于網(wǎng)絡(luò)接口訪問,有機(jī)會(huì)的話,可能再發(fā)一篇通過接口得到數(shù)據(jù)的GUI,思路、代碼方面有什么不足歡迎各位大佬指正、批評(píng)!
以上就是python 制作本地應(yīng)用搜索工具的詳細(xì)內(nèi)容,更多關(guān)于python 制作應(yīng)用搜索工具的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Python基于爬蟲實(shí)現(xiàn)全網(wǎng)搜索并下載音樂
- Python實(shí)現(xiàn)中英文全文搜索的示例
- python搜索算法原理及實(shí)例講解
- Python大批量搜索引擎圖像爬蟲工具詳解
- Python利用Faiss庫實(shí)現(xiàn)ANN近鄰搜索的方法詳解
- 利用python對(duì)mysql表做全局模糊搜索并分頁實(shí)例
- Python爬蟲爬取百度搜索內(nèi)容代碼實(shí)例
- python爬蟲開發(fā)之使用python爬蟲庫requests,urllib與今日頭條搜索功能爬取搜索內(nèi)容實(shí)例
- python實(shí)現(xiàn)全排列代碼(回溯、深度優(yōu)先搜索)
- python采集百度搜索結(jié)果帶有特定URL的鏈接代碼實(shí)例
- python 制作磁力搜索工具
相關(guān)文章
Pytorch 實(shí)現(xiàn)變量類型轉(zhuǎn)換
這篇文章主要介紹了Pytorch 實(shí)現(xiàn)變量類型轉(zhuǎn)換操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05PyTorch里面的torch.nn.Parameter()詳解
今天小編就為大家分享一篇PyTorch里面的torch.nn.Parameter()詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-01-01詳解Numpy擴(kuò)充矩陣維度(np.expand_dims, np.newaxis)和刪除維度(np.squeeze)的方
這篇文章主要介紹了詳解Numpy擴(kuò)充矩陣維度(np.expand_dims, np.newaxis)和刪除維度(np.squeeze)的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03如何用定值 Cookie 實(shí)現(xiàn)反爬詳解
這篇文章主要為大家介紹了如何用定值 Cookie 實(shí)現(xiàn)反爬示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04python 剪切移動(dòng)文件的實(shí)現(xiàn)代碼
移動(dòng)復(fù)制文件通過os.rename方法,先進(jìn)行文件是否存在判斷,如需更加復(fù)雜相同文件判斷可以根據(jù)文件屬性進(jìn)行判斷,此處只使用同名檢查,并刪除已存在文件,來實(shí)現(xiàn)覆蓋。這篇文章主要介紹了python 剪切移動(dòng)文件的實(shí)現(xiàn)代碼,需要的朋友可以參考下2018-08-08Python logging設(shè)置和logger解析
這篇文章主要介紹了Python logging設(shè)置和logger解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08Python語言實(shí)現(xiàn)百度語音識(shí)別API的使用實(shí)例
這篇文章主要介紹了Python語言實(shí)現(xiàn)百度語音識(shí)別API的使用實(shí)例,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12Python?gRPC流式通信協(xié)議詳細(xì)講解
這篇文章主要介紹了Python?gRPC流式通信協(xié)議,最近幾天在搞golang的grpc,跑通之后想用php作為客戶端調(diào)用一下grpc服務(wù),結(jié)果拉了,一個(gè)php的grpc服務(wù)安裝,搞了好幾天,總算搞定了2022-11-11Python3.5編程實(shí)現(xiàn)修改IIS WEB.CONFIG的方法示例
這篇文章主要介紹了Python3.5編程實(shí)現(xiàn)修改IIS WEB.CONFIG的方法,涉及Python針對(duì)xml格式文件的讀寫以及節(jié)點(diǎn)操作相關(guān)技巧,需要的朋友可以參考下2017-08-08