python 制作本地应用搜索工具
作者:懷淰メ 发布时间:2023-03-25 02:16:50
标签:python,应用,搜索,工具
目录
一.准备工作
二.预览
1.启动
2.运行
3.结果
三.设计思路
四.源代码
4.1 GUI.py
4.2 Search_Apps.py
五.总结
一.准备工作
请确保已经安装tkinter、pyperclip、threading
二.预览
1.启动
这是程序启动的主界面。
2.运行
搜索之后的界面。
3.结果
选择应用,右击鼠标复制它的下载链接。
三.设计思路
四.源代码
本次还是将GUI和搜索引擎分离开来,只要下面两个py文件在一个文件夹,结合已有的数据库就能实现上述功能。
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显示搜索结果
-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()
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
五.总结
本次使用tkinter制作了一款应用搜索工具,使用其中的Treeview显示搜索结果,使用Menu绑定相关操作,通过执行Mongodb查询语句得到相关数据,所以要结合本地Mongodb数据库,整体执行效率高于网络接口访问,有机会的话,可能再发一篇通过接口得到数据的GUI,思路、代码方面有什么不足欢迎各位大佬指正、批评!
来源:https://blog.csdn.net/a1397852386/article/details/114027941
0
投稿
猜你喜欢
- 1.必需的参数:必须参数须以正确的顺序传入函数,调用的数量必须和声明时的一样def f(name,age):print('I am
- #!/usr/bin/env pythonimport sys,timefrom socket import socketdef read_
- 比较说明1、break和continue是python两个关键字2、break和continue只能用在循环中3、break是终止循环的执行
- 前言:通常我们创建类都是使用class 类名,但是小伙伴们有没有想过,类是由谁来创建的呢,python中常说的万物皆对象,对象是由类创建的,
- 微博模拟登录这是本次爬取的网址:https://weibo.com/一、请求分析找到登录的位置,填写用户名密码进行登录操作看看这次请求响应的
- 模块:xmllibxmllib 是一个非验证的低级语法分析器。应用程序员使用的 xmllib 可以覆盖 XMLParser 类,并提供处理文
- 一、概述网络爬虫(Web crawler),又称为网络蜘蛛(Web spider)或网络机器人(Web robot),主要用来爬取目标网站内
- 每天工作忙,学会python自动收发邮件,代替你问候女友1、相关库介绍1)yagmailYet Another GMAIL/SMTP cli
- 前言:这个系列的专栏是为了保持 Python 手感而创建的,也可以用来学习 Python,因为存在知识跨越难度,所以先学习滚雪球系列为佳。二
- 常用的网站性能测试指标有:并发数、响应时间、吞吐量、性能计数器等。1、并发数并发数是指系统同时能处理的请求数量,这个也是反应了系统的负载能力
- 目录总体解决方案输出报表自动化Py脚本打包 EXE 桌面小程序好几个月没有写笔记了, 并非没有积累, 而是有点懒了. 想想还是要续上, 作为
- VBSCRIPT中的日期,时间,星期函数很丰富,给我们使用带来了很大的方便,我个人使用最多的就是用now()来获取服务器的当前日期和时间。但
- 阅读上一篇:javascript面向对象编程(二) [Interface,Class.implement 接口及实现]接口规定了一些方法,如
- onactivate
- 阅读系列教程上一篇:FrontPage2002简明教程二:文字与图像的处理通常网页的布局使用到的是FrontPage 2002中的表格和框架
- 本文实例讲述了Django中实现点击图片链接强制直接下载的方法。分享给大家供大家参考。具体分析如下:当用户点击图片连接时,默认为在浏览器中直
- 关于 游标 if,for 的例子 create or replace procedure peace_if is cursor var_c
- 本文实例讲述了php将12小时制转换成24小时制的方法。分享给大家供大家参考。具体如下:php将12小时制转换成24小时制,输入格式为:02
- 其实网上已经有很多这样的类了,不过出于练手的目的还是自己仿照着写了一个。下面的代码放在一个名为UploadFile.class.php文件内
- 介绍当在图像上训练深度神经网络模型时,通过对由数据增强生成的更多图像进行训练,可以使模型更好地泛化。常用的增强包括水平和垂直翻转/移位、以一