欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python 制作本地應用搜索工具

 更新時間:2021年02月27日 16:33:55   作者:懷淰メ  
這篇文章主要介紹了python 制作本地應用搜索工具的方法,幫助大家更好的理解和學習使用python,感興趣的朋友可以了解下

一.準備工作

請確保已經(jīng)安裝tkinter、pyperclip、threading

二.預覽

1.啟動

這是程序啟動的主界面。

2.運行

搜索之后的界面。

3.結(jié)果

選擇應用,右擊鼠標復制它的下載鏈接。

三.設計思路

四.源代碼

本次還是將GUI和搜索引擎分離開來,只要下面兩個py文件在一個文件夾,結(jié)合已有的數(shù)據(jù)庫就能實現(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綁定復制鏈接

'''
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='聯(lián)系作者',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數(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)}]個關于[{key_word}]的應用')
   elif self.data is False:
    self.l2.config(background='red')
    self.l2_var.set(f'數(shù)據(jù)庫連接失敗,請檢查數(shù)據(jù)庫配置!')
   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當前選中項數(shù)據(jù)
  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('聯(lián)系作者', '作者QQ:xxxx')

 def show_explain(self):
  messagebox.showinfo('說明', '\r本軟件僅供學習,請勿用于商業(yè)用途\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()

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制作了一款應用搜索工具,使用其中的Treeview顯示搜索結(jié)果,使用Menu綁定相關操作,通過執(zhí)行Mongodb查詢語句得到相關數(shù)據(jù),所以要結(jié)合本地Mongodb數(shù)據(jù)庫,整體執(zhí)行效率高于網(wǎng)絡接口訪問,有機會的話,可能再發(fā)一篇通過接口得到數(shù)據(jù)的GUI,思路、代碼方面有什么不足歡迎各位大佬指正、批評!

以上就是python 制作本地應用搜索工具的詳細內(nèi)容,更多關于python 制作應用搜索工具的資料請關注腳本之家其它相關文章!

相關文章

  • Pytorch 實現(xiàn)變量類型轉(zhuǎn)換

    Pytorch 實現(xiàn)變量類型轉(zhuǎn)換

    這篇文章主要介紹了Pytorch 實現(xiàn)變量類型轉(zhuǎn)換操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • PyTorch里面的torch.nn.Parameter()詳解

    PyTorch里面的torch.nn.Parameter()詳解

    今天小編就為大家分享一篇PyTorch里面的torch.nn.Parameter()詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • 詳解Numpy擴充矩陣維度(np.expand_dims, np.newaxis)和刪除維度(np.squeeze)的方法

    詳解Numpy擴充矩陣維度(np.expand_dims, np.newaxis)和刪除維度(np.squeeze)的方

    這篇文章主要介紹了詳解Numpy擴充矩陣維度(np.expand_dims, np.newaxis)和刪除維度(np.squeeze)的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • 利用python批量給云主機配置安全組的方法教程

    利用python批量給云主機配置安全組的方法教程

    這篇文章主要給大家介紹了利用python批量給云主機配置安全組的方法教程,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。
    2017-06-06
  • 如何用定值 Cookie 實現(xiàn)反爬詳解

    如何用定值 Cookie 實現(xiàn)反爬詳解

    這篇文章主要為大家介紹了如何用定值 Cookie 實現(xiàn)反爬示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • python 剪切移動文件的實現(xiàn)代碼

    python 剪切移動文件的實現(xiàn)代碼

    移動復制文件通過os.rename方法,先進行文件是否存在判斷,如需更加復雜相同文件判斷可以根據(jù)文件屬性進行判斷,此處只使用同名檢查,并刪除已存在文件,來實現(xiàn)覆蓋。這篇文章主要介紹了python 剪切移動文件的實現(xiàn)代碼,需要的朋友可以參考下
    2018-08-08
  • Python logging設置和logger解析

    Python logging設置和logger解析

    這篇文章主要介紹了Python logging設置和logger解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • Python語言實現(xiàn)百度語音識別API的使用實例

    Python語言實現(xiàn)百度語音識別API的使用實例

    這篇文章主要介紹了Python語言實現(xiàn)百度語音識別API的使用實例,具有一定借鑒價值,需要的朋友可以參考下。
    2017-12-12
  • Python?gRPC流式通信協(xié)議詳細講解

    Python?gRPC流式通信協(xié)議詳細講解

    這篇文章主要介紹了Python?gRPC流式通信協(xié)議,最近幾天在搞golang的grpc,跑通之后想用php作為客戶端調(diào)用一下grpc服務,結(jié)果拉了,一個php的grpc服務安裝,搞了好幾天,總算搞定了
    2022-11-11
  • Python3.5編程實現(xiàn)修改IIS WEB.CONFIG的方法示例

    Python3.5編程實現(xiàn)修改IIS WEB.CONFIG的方法示例

    這篇文章主要介紹了Python3.5編程實現(xiàn)修改IIS WEB.CONFIG的方法,涉及Python針對xml格式文件的讀寫以及節(jié)點操作相關技巧,需要的朋友可以參考下
    2017-08-08

最新評論