iis服务器助手广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python 制作磁力搜索的工具
  • 873
分享到

python 制作磁力搜索的工具

2023-06-06 18:06:27 873人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

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

这篇文章主要讲解了“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 制作磁力搜索的工具这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: python 制作磁力搜索的工具

本文链接: https://www.lsjlt.com/news/248221.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • python 制作磁力搜索的工具
    这篇文章主要讲解了“python 制作磁力搜索的工具”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python 制作磁力搜索的工具”吧!一.准备工作装库,主要有tkinter os thre...
    99+
    2023-06-06
  • 基于Python制作一个简单的文章搜索工具
    目录 前言功能实现导入模块创建窗口背景图片搜索文本框 内容显示界面搜索内容效果代码展示内容效果代码点击搜索功能代码访问博客网页 前言 今天,我无聊的时候...
    99+
    2023-05-12
    Python实现文章搜索工具 Python文章搜索工具 Python文章搜索 Python 搜索工具
  • Python利用PaddleOCR制作个搜题小工具
    目录介绍安装安装PaddlePaddle飞桨框架安装PaddleOCR代码使用搜题小工具安装ADB截图并保存题目区域图片OCR识别,获取题目打开浏览器搜索完整代码介绍 PaddleO...
    99+
    2024-04-02
  • 利用Python实现自制文件搜索小工具
    目录前言环境准备完整代码前言 嗨嗨,大家晚上好 ~ 当自己电脑文件很多还有点乱,不记得自己文件放哪里的时候,用电脑自带的搜索文件,这个等待时间可慢了 对我们这种敲代码的,这能忍吗,...
    99+
    2024-04-02
  • 用.NET开发的磁力搜索引擎——btbook.net
    btbook.net是一个基于.NET开发的磁力搜索引擎。它提供了一个简单、高效的搜索界面,用户可以通过输入关键词来搜索磁力链接。搜...
    99+
    2023-09-20
    .NET
  • 使用python制作一个批量查询搜索排名的SEO免费工具
    💂 个人网站:【海拥】【摸鱼游戏】【神级源码资源网】🤟 前端学习课程:👉【28个案例趣学前端】【400个JS面试题】💅 寻找学习交流...
    99+
    2023-08-31
    python 开发语言
  • Python如何利用PaddleOCR制作个搜题小工具
    这篇文章主要介绍“Python如何利用PaddleOCR制作个搜题小工具”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python如何利用PaddleOCR制作个搜题小工具”文章能帮助大家解决问题。...
    99+
    2023-07-02
  • Whoosh:Python 的轻量级搜索工具
    Whoosh简介 Whoosh由Matt Chaput创建,它一开始是一个为Houdini 3D动画软件包的在线文档提供简单、快速的搜索服务工具,之后便慢慢成为一个成熟的搜索解决工具并已开源。 Whoosh纯由Python编写而成,是一个灵...
    99+
    2023-05-14
    工具 Python Whoosh
  • 用python实现一个文件搜索工具
    目录前言步骤操作如下:完整代码:总结前言 经常使用电脑自带的搜索很慢很卡,今天做一个搜索工具,可以搜索到隐藏的文件,而且速度也很快 步骤 导入模块 import os 检测一下输入的...
    99+
    2024-04-02
  • Python轻量级搜索工具Whoosh的使用教程
    目录Whoosh简介Index & query示例代码数据字段创建索引文件查询本文将简单介绍Python中的一个轻量级搜索工具Whoosh,并给出相应的使用示例代码。 Who...
    99+
    2024-04-02
  • Python轻量级搜索工具Whoosh怎么使用
    这篇文章主要介绍了Python轻量级搜索工具Whoosh怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python轻量级搜索工具Whoosh怎么使用文章都会有所收获,下面我们一起来看看吧。Whoosh简...
    99+
    2023-07-02
  • 使用Python多线程爬虫实现磁力链接搜索神器
    要实现一个磁力链接搜索神器,你可以使用Python的多线程爬虫来爬取磁力链接网站上的数据。以下是一个简单的示例代码:```pytho...
    99+
    2023-08-23
    python
  • Python+tkinter实现制作文章搜索软件
    目录前言环境使用模块使用最终效果界面实现代码导入模块创建窗口标题图片搜索框内容显示界面内容效果代码前言 无聊的时候做了一个搜索文章的软件,有没有更加的方便快捷不知道,好玩就行了 环境...
    99+
    2024-04-02
  • 基于Python+OpenCV制作屏幕录制工具
    目录应用平台屏幕录制部分计算视频最优fps及使用numpy计算中间帧数组使用pynput监听键盘按键如何保存MP4格式视频源码总结最近有在使用屏幕录制软件录制桌面,在用的过程中突发奇...
    99+
    2024-04-02
  • 基于Python制作个抢红包的工具
    目录1. 概述2. 环境3. 实现1. 概述 快过年了,刚刚收到了两个消息,一个好消息,一个坏消息。 先说好消息,好消息就是微信群里有人要发红包,开心~ 不过转念一想,前几次的红包一...
    99+
    2023-01-10
    Python抢红包工具 Python抢红包 Python 红包
  • python的web压力测试工具-pyl
    pylot是python编写的一款web压力测试工具。使用比较简单。而且测试结果相对稳定。 这里不得不鄙视一下apache 的ab测试,那结果真是让人蛋疼,同样的url,测试结果飘忽不定,看得人心惊肉跳,摸不着头脑。 下载 pylot官...
    99+
    2023-01-31
    测试工具 压力 python
  • 怎么用Python实现基于Pyqt5的简单电影搜索工具
    这篇文章主要介绍“怎么用Python实现基于Pyqt5的简单电影搜索工具”,在日常操作中,相信很多人在怎么用Python实现基于Pyqt5的简单电影搜索工具问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用...
    99+
    2023-06-02
  • 使用python怎么编写一个本地应用搜索工具
    这篇文章主要介绍了使用python怎么编写一个本地应用搜索工具,此处通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考价值,需要的朋友可以参考下:python可以做什么Python是一种编程语言,内置了许多有效的工具,Pyt...
    99+
    2023-06-06
  • python如何制作的天气预报小工具
    这篇文章主要介绍python如何制作的天气预报小工具,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一.准备工作不需要准备。二.预览1.启动启动以后自动定位所在城市,展示定位城市的天气。2.添加城市3.展示多个城市天气...
    99+
    2023-06-15
  • 基于Python制作一个多进制转换工具
    目录前言主要步骤完整代码前言 学习资料下载链接 提取码:9d4g  进制转换计算工具含源文件 主要步骤 导入模块 import tkinter from tki...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作