這篇文章主要介紹了使用python怎么編寫一個本地應用搜索工具,此處通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考價值,需要的朋友可以參考下:
Python是一種編程語言,內置了許多有效的工具,Python幾乎無所不能,該語言通俗易懂、容易入門、功能強大,在許多領域中都有廣泛的應用,例如最熱門的大數據分析,人工智能,Web開發等。

GUI.py
from tkinter import *
from tkinter import ttk
from tkinter import messagebox
from Search_Apps import Find_APP
import threading
import pyperclip
'''
-treeview顯示搜索結果
-Menu綁定復制鏈接
'''
class App:
def __init__(self):
self.w=Tk()
self.w.title('應用搜索工具(本地版)-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='關鍵字:')
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="序號")
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('請先搜索')
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='關于',menu=self.s2)
self.s1.add_command(label='搜索',command=lambda :self.thread_it(self.search_app))
self.s1.add_command(label='復制下載地址',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='聯系作者',command=self.show_info)
self.w.protocol('WM_DELETE_WINDOW',self.quit_window)
self.m2.add_command(label='復制鏈接',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數據
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)}]個關于[{key_word}]的應用')
elif self.data is False:
self.l2.config(background='red')
self.l2_var.set(f'數據庫連接失敗,請檢查數據庫配置!')
else:
self.l2.config(background='green')
self.l2_var.set(f'沒有檢索到關于[{key_word}]的應用')
else:
messagebox.showwarning('警告','請輸入關鍵字!')
self.l2.config(background='red')
self.l2_var.set(f'請輸入關鍵字!')
def display_infos(self,event):
#獲取treeview當前選中項數據
curr=self.tree.item(self.tree.focus()).get('values')
#獲取treeview當前選中項索引
# 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('聯系作者', '作者QQ:xxxx')
def show_explain(self):
messagebox.showinfo('說明', '\r本軟件僅供學習,請勿用于商業用途\n\n1.在輸入框輸入關鍵字進行搜索\n2.選擇應用右擊提取下載地址')
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('提示','下載地址已成功復制到剪切板!')
except AttributeError:
messagebox.showwarning('警告','請先選中應用!')
self.l2.config(background='red')
self.l2_var.set('請先選中應用!')
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()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到此這篇關于使用python怎么編寫一個本地應用搜索工具的文章就介紹到這了,更多相關使用python怎么編寫一個本地應用搜索工具的內容請搜索億速云以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持億速云!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。