我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python 制作磁力搜索的工具

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python 制作磁力搜索的工具

这篇文章主要讲解了“python 制作磁力搜索的工具”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python 制作磁力搜索的工具”吧!

一.准备工作

装库,主要有tkinter os threading win32 pillow

二.预览

预览我们的软件

1.启动

python 制作磁力搜索的工具

2.运行

python 制作磁力搜索的工具

3.结果

可以选择保存链接到本地,也可以选择复制链接倒剪切板。

3.1保存到本地:

保存格式为txt

python 制作磁力搜索的工具

3.2复制链接:

复制以后,如果存在第三方下载工具,就能在工具中打开。

python 制作磁力搜索的工具

三.tk源代码

设计流程就不说了,本次设计主要在界面布局上。这里直接上源代码。

#coding:utf-8from tkinter import ttkfrom tkinter import *from tkinter import messageboxfrom tkinter.filedialog import askdirectoryimport tkinter.simpledialogfrom PIL import Image,ImageTkimport osimport threadingimport win32clipboard as wfrom Spiders.spider1 import magent_spider1from Spiders.spider2 import magent_spider2from Spiders.spider3 import magent_spider3from Spiders.spider4 import magent_spider4from QQ_infos import QQ_data#spider1和spider4比较稳定imgs=['lsj.png']class App: def __init__(self):  self.window=Tk()  self.window.resizable(0,0)  width=420  height=400  screen_width=self.window.winfo_screenwidth()  screen_height=self.window.winfo_screenheight()  left=(screen_width-width)/2  top=(screen_height-height)/2  self.window.geometry('%dx%d+%d+%d'%(width,height,left,top))  self.window.title('老司机搜索器-v1.0')  self.create_widget()  self.place_sidget()  self.set_config()  self.window.mainloop() def create_widget(self):  self.l1=ttk.Label(self.window,text='选择引擎:')  self.r_chose=StringVar()  self.filepath=StringVar()  self.ls_var=StringVar()  self.l5_var=StringVar()  self.l_p_var=StringVar()  self.qq_screenname_var=StringVar()  self.r1=Radiobutton(self.window,text='引擎一',value='1',variable=self.r_chose)  self.r2=Radiobutton(self.window,text='引擎二',value='2',variable=self.r_chose)  self.r3=Radiobutton(self.window,text='引擎三',value='3',variable=self.r_chose)  self.r4=Radiobutton(self.window,text='引擎四',value='4',variable=self.r_chose)  self.l2=ttk.Label(self.window,text='关键字:')  self.e1=ttk.Entry(self.window)  self.b1=ttk.Button(self.window,text='搜索',)  self.l3 = ttk.Label(self.window, text='存储路径:')  self.e2 = ttk.Entry(self.window,textvariable=self.filepath)  self.b2 = ttk.Button(self.window, text='选择目录')  self.qq_screenname=ttk.Label(self.window,textvariable=self.qq_screenname_var)  self.ls=Label(self.window,bg='pink',textvariable=self.ls_var)  self.listbox=Listbox(self.window,selectmode=SINGLE)  self.S_coll_vertical = Scrollbar(self.window, orient=VERTICAL)  self.S_coll_level = Scrollbar(self.window, orient=HORIZONTAL)  self.b3=ttk.Button(self.window,text='保存')  self.paned = PanedWindow(self.window)  self.img=imgs  img = Image.open(self.img[0])  photo = img.resize((180, 190))  self.paned.image = ImageTk.PhotoImage(photo)  self.l4=Label(self.window,image=self.paned.image,)  self.b4=ttk.Button(self.window,text='上一页')  self.l_p=ttk.Label(self.window,textvariable=self.l_p_var,background='orange')  self.b5=ttk.Button(self.window,text='下一页')  self.l5=ttk.Label(self.window,text='影片信息:',)  self.m=Menu(self.window)  self.s1=Menu(self.m,tearoff=False)  self.s2=Menu(self.m,tearoff=False)  self.s3=Menu(self.m,tearoff=False) def place_sidget(self):  self.l1.place(x=20,y=12)  self.r1.place(x=100,y=10)  self.r2.place(x=180,y=10)  self.r3.place(x=260,y=10)  self.l2.place(x=20,y=45)  self.e1.place(x=90,y=40,height=30,width=120)  self.b1.place(x=230,y=40,width=80)  self.l3.place(x=20,y=85)  self.e2.place(x=90,y=80,height=30,width=120)  self.b2.place(x=230,y=80,width=80)  self.ls.place(x=0,y=114,width=420,height=22)  self.listbox.place(x=20,y=140,width=190,height=180)  self.b3.place(x=230,y=140,width=80)  self.S_coll_vertical.place(x=200, y=140,width=15,height=180)  self.S_coll_level.place(x=20, y=310,width=190,height=15)  self.paned.place(x=230,y=170,height=180,width=300)  self.b4.place(x=15,y=328,width=60)  self.l_p.place(x=85,y=331,)  self.b5.place(x=145,y=328,width=60)  self.l4.place(x=215,y=170,height=200,width=220)  self.l5.place(x=0,y=365,height=25,width=420) def set_config(self):  self.lock=True  self.ls_var.set('---还未搜索---')  self.b1.config(command=self.search_res)  self.r_chose.set(1)  self.S_coll_vertical.config(command=self.listbox.yview)  self.listbox['yscrollcommand'] = self.S_coll_vertical.set  self.S_coll_level.config(command=self.listbox.xview)  self.listbox['xscrollcommand'] = self.S_coll_level.set  self.window['menu']=self.m  self.s1.add_command(label='选择目录',command=self.open_file_savepath)  self.s1.add_command(label='打开文件夹',command=self.open_dir)  self.s1.add_separator()  self.s1.add_command(label='退出',command=self.quit_window)  self.m.add_cascade(label='文件',menu=self.s1)  self.m.add_cascade(label='操作',menu=self.s2)  self.m.add_cascade(label='关于',menu=self.s3)  self.s2.add_command(label='搜索',command=lambda :self.thread_it(self.search_res))  self.s2.add_command(label='复制',command=lambda :self.thread_it(self.copy_magent))  self.s2.add_command(label='保存',command=lambda :self.thread_it(self.save_magent))  self.s3.add_command(label='联系作者',command=self.show_QQ)  self.s3.add_command(label='解锁隐藏引擎',command=self.unlock_engine)  self.b1.config(command=lambda :self.thread_it(self.search_res))  self.b3.config(command=lambda :self.thread_it(self.save_magent))  self.b4.config(command=lambda :self.thread_it(self.page_min))  self.b5.config(command=lambda :self.thread_it(self.page_add))  self.l5.config(textvariable=self.l5_var,background='#008080')  self.b2.config(command=self.open_file_savepath)  self.l_p_var.set('页码:')  self.listbox.bind('<<ListboxSelect>>',self.display_infos)  # 绑定esc键---退出  self.window.bind('<Escape>', self.escape)  # 使用return键给输入框Entry绑定enter事件---search搜索  self.e1.bind('<Return>', self.enter)  self.window.protocol('WM_DELETE_WINDOW',self.quit_window) def enter(self):  self.search_res() def escape(self,event):  self.quit_window() def quit_window(self):  ask=messagebox.askyesno('退出','真的要退出吗?')  if ask:   self.window.destroy() def open_file_savepath(self):  self.file = askdirectory()  self.filepath.set(self.file)  abs_path = os.path.abspath(self.filepath.get())  self.magnetic_dir = abs_path def open_dir(self):  os.startfile(self.magnetic_dir) def show_QQ(self):  messagebox.showinfo('联系作者','作者QQ:xxxxxxxxx') def search_res(self):  key_word=self.e1.get()  self.ls_var.set('')  self.page=1  if key_word:   # print(self.r_chose.get())   self.listbox.delete(0,END)   #使用self.r_chose.get()判断选中了哪个   if self.r_chose.get()=='1':    spider1=magent_spider1()    self.speed,self.flag,self.result_list= spider1.get_data(key_word,1)    if self.speed is None:     messagebox.showinfo('提示','此引擎停用!')     self.r1.config(state='disable')    self.ls_var.set(self.speed)    self.l_p_var.set('页码:1')    for data in self.result_list:     title = data.split(')-*/(')[0]     self.listbox.insert(END, title)   elif self.r_chose.get()=='2':    spider2=magent_spider2()    self.speed,self.flag,self.result_list=spider2.get_data(key_word,1)    if self.speed is None:     messagebox.showinfo('提示','此引擎停用!')     self.r2.config(state='disable')    else:     self.ls_var.set(self.speed)     for data in self.result_list:      title = data.split(')-*/(')[0]      self.listbox.insert(END, title)   #爬虫3只返回flag和result_list   elif self.r_chose.get()=='3':    spider3=magent_spider3()    self.flag, self.result_list = spider3.get_data(key_word, 1)    if self.flag:     self.ls_var.set(f'搜索到关于{key_word}的资源')     self.l_p_var.set('页码:1')     for data in self.result_list:      title = data.split(')-*/(')[0]      self.listbox.insert(END, title)    else:     messagebox.showinfo('提示','此引擎停用!')     self.r3.config(state='disable')   elif self.r_chose.get()=='4':    spider4=magent_spider4()    self.speed,self.flag,self.result_list=spider4.get_data(key_word,1)    if self.speed is None:     messagebox.showinfo('提示','此引擎停用!')     self.r4.config(state='disable')    else:     self.l_p_var.set('页码:1')     self.ls_var.set(self.speed)     for data in self.result_list:      title = data.split(')-*/(')[0]      self.listbox.insert(END, title)   self.listbox.update()  else:   messagebox.showwarning('警告','请先输入关键字!') def display_infos(self,event):  try:   curr_content_index=self.listbox.curselection()[0]   content=self.result_list[curr_content_index].split(']-*/[')[0]   pre_con=content.split(')-*/(')[0]   aft_con = ' 大小:' + content.split(')-*/(')[1]   if len(pre_con)>45:    #print(self.listbox[curr_content_index])    self.l5_var.set(aft_con)   else:    self.l5_var.set(pre_con+aft_con)  except IndexError:   pass def do_turn_page(self,page):  self.listbox.delete(0, END)  key_word=self.e1.get()  if self.r_chose.get()=='1':   spider1 = magent_spider1()   self.flag=spider1.get_data(key_word, page)[1]   if self.flag:    self.result_list = spider1.get_data(key_word, page)[2]  elif self.r_chose.get()=='2':   spider2 = magent_spider2()   self.flag=spider2.get_data(key_word, page)[1]   if self.flag:    self.result_list = spider2.get_data(key_word, page)[2]  elif self.r_chose.get()=='3':   spider3 = magent_spider3()   self.flag,self.result_list=spider3.get_data(key_word, page)  elif self.r_chose.get()=='4':   spider4 = magent_spider4()   self.flag = spider4.get_data(key_word, page)[1]   if self.flag:    self.result_list = spider4.get_data(key_word, page)[2]  if self.flag:   for data in self.result_list:    title = data.split(')-*/(')[0]    self.listbox.insert(END, title)   self.listbox.update()  else:   messagebox.showinfo('提示','已经是最后一页') def page_min(self):  if self.page==1:   messagebox.showwarning('警告','当前已经是第一页了')  else:   self.page-=1   self.l_p_var.set('页码:'+str(self.page))   self.do_turn_page(self.page)   self.listbox.update() def page_add(self):  if self.flag is False :   messagebox.showwarning('警告','当前已经是最后一页了')  else:   self.page += 1   self.l_p_var.set('页码:'+str(self.page))   self.do_turn_page(self.page)   self.listbox.update() def get_magnet(self):  try:   curr_content_index = self.listbox.curselection()[0]   hashes = self.result_list[curr_content_index].split(']-*/[')[-1]   file_name=self.result_list[curr_content_index].split(')-*/(')[0]   if self.r_chose.get()=='1':    spider1=magent_spider1()    magnet=spider1.get_megent(hashes)    return file_name, magnet   elif self.r_chose.get() == '2':    spider2 = magent_spider2()    magnet = spider2.get_magent(hashes)    return file_name, magnet   elif self.r_chose.get() == '3':    spider3 = magent_spider3()    magnet = spider3.get_magent(hashes)    return file_name, magnet   elif self.r_chose.get() == '4':    spider4 = magent_spider4()    magnet = spider4.get_magent(hashes)    return file_name, magnet  except IndexError:   messagebox.showwarning('警告','请先选中要下载的资源!') def save_magent(self):  if os.path.exists(self.filepath.get()):   try:    filename, magent_link=self.get_magnet()    if '.' in filename:     filename=filename.replace('.','')    file_path=self.magnetic_dir    with open(file_path+filename+'.txt','w')as f:     f.write(magent_link)    messagebox.showinfo('提示','保存磁力链接成功!')   except TypeError:    pass  else:   messagebox.showwarning('警告', '您还未选择路径!') def copy_magent(self):  magent_link=self.get_magnet()[1]  w.OpenClipboard()  w.EmptyClipboard()  w.SetClipboardText(magent_link)  w.CloseClipboard()  messagebox.showinfo('提示','磁力链接已经复制到了剪切板!') def unlock_engine(self):  if self.lock:   # 获取字符串(标题,提示,初始值)initialvalue初始值   qq_number = tkinter.simpledialog.askstring(title='解锁', prompt='请输入QQ号:', )   # 打印内容   qq_screenname=QQ_data(qq_number).get_screenname()   if qq_screenname:    self.qq_screenname_var.set('欢迎您:\n\n'+qq_screenname)    self.qq_screenname.config(font=(('Times',12)),foreground='Tomato')    self.qq_screenname.place(x=320,y=40)    QQ_data(qq_number).save_heade_img()    messagebox.showinfo('恭喜','解锁成功!')    self.img2=os.path.abspath('./')    self.img2+='/head_img/'+qq_number+'.jpg'    img = Image.open(self.img2)    photo = img.resize((190, 170))    self.paned.image = ImageTk.PhotoImage(photo)    self.l4 = Label(self.window, image=self.paned.image, )    self.l4.place(x=215, y=170, height=180, width=210)    self.r4.config(font=(('Times',12)),foreground='blue')    self.l4.config(background='red')    self.r4.place(x=340, y=10)    self.lock=False   else:    messagebox.showerror('错误','解锁失败!')  else:   messagebox.showwarning('警告','您已成功解锁!') def thread_it(self,func,*args):  t=threading.Thread(target=func,args=args)  t.setDaemon(True)  t.start()if __name__ == '__main__': a=App()

感谢各位的阅读,以上就是“python 制作磁力搜索的工具”的内容了,经过本文的学习后,相信大家对python 制作磁力搜索的工具这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python 制作磁力搜索的工具

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python 制作磁力搜索的工具

这篇文章主要讲解了“python 制作磁力搜索的工具”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python 制作磁力搜索的工具”吧!一.准备工作装库,主要有tkinter os thre
2023-06-06

基于Python制作一个简单的文章搜索工具

目录 前言功能实现导入模块创建窗口背景图片搜索文本框 内容显示界面搜索内容效果代码展示内容效果代码点击搜索功能代码访问博客网页 前言今天,我无聊的时候做了一个搜索文章的软件,有没有更加的方便快捷不知道,好玩就行了。基于Python tki
2023-05-12

Python如何利用PaddleOCR制作个搜题小工具

这篇文章主要介绍“Python如何利用PaddleOCR制作个搜题小工具”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python如何利用PaddleOCR制作个搜题小工具”文章能帮助大家解决问题。
2023-07-02

Python轻量级搜索工具Whoosh的使用(总结分享)

本篇文章给大家带来了关于Python的相关知识,将为大家简单介绍一下Python中的一个轻量级搜索工具Whoosh,并给出相应的使用示例代码,下面一起来看一下,希望对大家有帮助。【相关推荐:Python3视频教程 】本文将简单介绍Python中的一个轻量级搜索工具Whoosh,并给出相应的使用示例代码。Whoosh简介Whoosh由Matt Chaput创建,它一开始是一个为Houdini 3D动画
2022-08-08

安装ElasticSearch搜索工具并配置Python驱动的方法

ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java开发的,并作为Apache许可条款下的开放源码发布,是第二流行的
2022-06-04

基于Python制作个抢红包的工具

快过年了,刚刚收到了两个消息,一个好消息,一个坏消息。好消息就是微信群里有人要发红包,坏消息是不一定能都抢到。所以本文就来用Python做一个抢红包工具,需要的可以参考一下
2023-01-10

Solr搜索引擎的核心架构及工作原理详解(Solr搜索引擎的内部结构和工作机制是怎样的?)

Solr搜索引擎基于ApacheLucene构建,具有高性能、可扩展性和容错性。其核心架构包括模式、核心、处理器、索引、文档、查询、结果和分面。Solr的工作原理包含索引构建、查询解析、查询优化、查询执行、结果排序、分面聚合等步骤。Solr具备高性能、可扩展性、容错性、可定制性和社区支持等优势,使其广泛用于各种应用程序中。
Solr搜索引擎的核心架构及工作原理详解(Solr搜索引擎的内部结构和工作机制是怎样的?)
2024-04-02

Sphinx全文搜索引擎的架构与工作原理详解(Sphinx搜索引擎的内部结构和工作机制是怎样的?)

Sphinx全文搜索引擎采用分布式架构,包括索引服务器、搜索服务器和代理服务器。索引建立过程涉及词项提取、分词和索引创建。搜索查询处理包括在倒排索引中查找匹配文档。结果返回包括从索引服务器获取内容并排序。Sphinx特点包括可伸缩性、高性能、相关性、灵活性、可配置性等,适用于电子商务搜索、网站搜索、数据挖掘等场景。
Sphinx全文搜索引擎的架构与工作原理详解(Sphinx搜索引擎的内部结构和工作机制是怎样的?)
2024-04-02

怎么用Python实现基于Pyqt5的简单电影搜索工具

这篇文章主要介绍“怎么用Python实现基于Pyqt5的简单电影搜索工具”,在日常操作中,相信很多人在怎么用Python实现基于Pyqt5的简单电影搜索工具问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用
2023-06-02

python如何制作的天气预报小工具

这篇文章主要介绍python如何制作的天气预报小工具,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一.准备工作不需要准备。二.预览1.启动启动以后自动定位所在城市,展示定位城市的天气。2.添加城市3.展示多个城市天气
2023-06-15

python 制作一个gui界面的翻译工具

目录一.准备工作二.预览1.主界面2.翻译3.支持多种语言哦三.源代码3.1 My_Translator-v2.0.py3.2 Translator.py四.总结一.准备工作除了Tkinter,还需要google_trans_new,没有安
2022-06-02

python制作的天气预报小工具(gui界面)

目录一.准备工作二.预览1.启动2.添加城市3.展示多个城市天气三.设计流程1.获取城市天气信息过程四.源代码1.Weather_Tool-v1.0.py2.Weather_Spider.py五.总结一.准备工作不需要准备。 二.预览1.启
2022-06-02

运算符的魔力:探索Python中操纵和分析数据的工具

运用运算符的力量,探索Python中操纵和分析数据的强大工具,释放数据的价值,从而做出明智、数据驱动的决策。
运算符的魔力:探索Python中操纵和分析数据的工具
2024-03-09

Python制作一个随机抽奖小工具的实现

目录1. 核心功能设计2. GUI设计与实现3. 功能实现3.1 读取人员名单3.2. 随机抽奖3.3. 保存中奖名单3.4. GUI交互逻辑最近在工作中面向社群玩家组织了一场活动,需要进行随机抽奖,参考之前小明大佬的案例,再结合自己的需求
2022-06-02

一款Python工具制作的动态条形图(强烈推荐!)

有时为了方便看数据的变化情况,需要画一个动态图来看整体的变化情况,下面这篇文章主要给大家介绍了一款Python工具制作的动态条形图的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2023-02-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录