今天看到everything搜索速度秒杀windows自带的文件管理器,所以特地模仿everything实现了文件搜索以及打开对应文件的功能,首先来一张搜索对比图。

这是evething搜索效果:

这是自己实现的效果:

主要功能就是python的os库的文件列表功能,sqllite创建表,插入数据以及模糊搜索,然后就是tkiner实现的界面功能。全部代码贴出来做一次记录,花费一天时间踩坑。

# coding=utf-8

import tkinter as tk

import tkinter.messagebox #这个是消息框,对话框的关键

import tkinter.constants

import sqlite3

import os

import threading

import traceback

def update_db():

print("更新数据库")

tkinter.messagebox.showerror("错误提示","更新数据库功能未完待续,可以删除目录下的allFiles.db文件,然后点击搜索,即可刷新数据库")

def mouseCallBack(*args):

indexs = listb.curselection()

index = int(indexs[0])

print("index",index)

start_directory = str(myArr[index])

print(start_directory[2:-3])

os.startfile(start_directory[2:-3])

def obtain_all_files(filepath,cursor):

#遍历filepath下所有文件,包括子目录

try:

files = os.listdir(filepath)

for fi in files:

fi_d = os.path.join(filepath,fi)

if os.path.isdir(fi_d):

obtain_all_files(fi_d,cursor)

else:

path = os.path.join(filepath,fi_d)

update_progress.set(path)

print("目录",path)

sqlAdd = "insert into filepath (file_path) values ('"+path+"')"

print("sqlAdd",sqlAdd)

cursor.execute(sqlAdd)

except Exception as e:

traceback.print_exc()

print("扫描文件出异常了,点击确定继续扫描")

tkinter.messagebox.showerror("错误提示","扫描文件出异常了看,点击确定继续扫描")

def scan_file():

print("开始扫描文件")

# del myArr[:]

connection.execute("BEGIN TRANSACTION;") # 关键点

cursor = connection.cursor()

obtain_all_files('G:\',cursor)

print("G盘扫描完成...")

tkinter.messagebox.showinfo("温馨提示","G盘扫描完成....")

connection.execute("COMMIT;") #关键点

connection.commit()

connection.close()

def insert_db():

t1 = threading.Thread(target=scan_file)

t1.setDaemon(True)

t1.start()

tkinter.messagebox.showinfo("温馨提示","正在更新数据库,请等待...")

def search_file():

#表示创建一个数据库,并获得连接

print("数据库是否存在: ",isExistDB)

if(isExistDB==False):

tkinter.messagebox.showwarning("警告","数据库不存在,将更新数据库文件!")

try:

mycursor = connection.cursor()

file_sql = "create table filepath('file_path' text not null)"

mycursor.execute(file_sql)

mycursor.close()

insert_db()

except:

tkinter.messagebox.showerror("错误提示","数据库发生异常...")

return

else:

print("开始搜索")

listb.delete(0,tk.constants.END)

mycursor = connection.cursor()

entry_text = inputText.get()

search_sql = "select * from filepath where file_path like '%"+entry_text+"%'"

files = mycursor.execute(search_sql)

#tkinter.messagebox.showwarning("警告","没有找到对应的文件!")

for f in files:

print(f)

myArr.append(f)

listb.insert(tkinter.constants.END,f)

print("搜索完成")

mycursor.close()

myArr = []

isExistDB = os.path.exists("allFiles.db")

connection = sqlite3.connect("allFiles.db",check_same_thread = False)

root = tk.Tk() # 初始化Tk()

root.title("电脑文件搜索工具(仿everything)By景兄弟V1.0") # 设置窗口标题

root.geometry("800x600") # 设置窗口大小 注意:是x 不是*

root.resizable(width=False, height=False) # 设置窗口是否可以变化长/宽,False不可变,True可变,默认为True

#设置输入框

inputText = tk.Entry(root,show=None,foreground = 'red',font = ('Helvetica', '15', 'bold'),insertbackground = 'green',width=65)

inputText.pack()

#设置按钮,以及放置的位置

searchBtn = tk.Button(root, text="搜索", fg="blue",bd=2,width=10,command=search_file)#command中的方法带括号是直接执行,不带括号才是点击执行

searchBtn.place(x=200, y=40, anchor='nw')

updateBtn = tk.Button(root, text="更新数据库", fg="blue",bd=2,width=10,command=update_db)

updateBtn.place(x=400, y=40, anchor='nw')

update_progress = tk.StringVar()

update_progress.set('还未开始扫描')

lb = tk.Label(root,text="还未开始", fg="blue",bd=2,width=100, textvariable=update_progress)

lb.place(x=20,y=90)

listb = tk.Listbox(root,width=110,height=20)

listb.place(x=1, y=120, anchor='nw')

sb = tk.Scrollbar(root) #垂直滚动条组件

sb.pack(side=tkinter.constants.RIGHT,fill=tkinter.constants.Y) #设置垂直滚动条显示的位置

listb.config(yscrollcommand=sb.set)

listb.bind("<>",mouseCallBack)

root.mainloop() # 进入消息循环

以上所述是小编给大家介绍的python仿evething的文件搜索器详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

在哪里能收到python实例代码-python仿evething的文件搜索器实例代码相关推荐

  1. python 遍历listbox_Python仿evething的文件搜索器 !

    今天看到everything搜索速度秒杀windows自带的文件管理器,所以特地模仿everything实现了文件搜索以及打开对应文件的功能,首先来一张搜索对比图. 这是evething搜索效果: P ...

  2. python播放wav文件_python3 写一个WAV音频文件播放器的代码

    环境:ubuntu 16.04 python3.5 pycharm 包 : wave pyaudio sys 上代码:AudioPlayer.py # coding:utf-8 # author:ki ...

  3. Linux如何全盘搜索MySQL文件_Linux上的文件搜索命令实例详解

    locate 基础了解 locate命令搜索的后台数据库路径:/var/lib/mlocate/mlocate.db ls -hl /var/lib/mlocate total 1.2M -rw-r- ...

  4. python怎么用excel-Python怎么写入excel文件?详细实例在这里。。。

    本文概述 Python写入excel文件用于使用xlwt模块在电子表格上执行多项操作.这是将数据和格式信息写入扩展名为.xls的文件的理想方法. 如果你想将数据写入任何文件, 又不想自己做任何麻烦, ...

  5. python tk 小案例:制作一个问题搜索器

    前言 嗨喽,大家好呀~这里是爱看美女的茜茜呐 又到了学Python时刻~ 在逛百度搜东西的时候,有一些杂乱的词条容易混入进来' 那么?我们能不能自己创建一个类似百度的搜索器呢? 当然是可以的,今天博主 ...

  6. java加vue实例_Vue.Js及Java实现文件分片上传代码实例

    upload(file) { //从后台获取已经上传的文件分片数 getIdx(md5) .then(function(res) { let retry = 3; uploadPart(retry, ...

  7. VC 写 TXT 文件分割器 附代码

    TXT文件分割器主要将很大的TXT文档分割成预定大小的文档 主要通过cfile类来实现 这就是最后的效果. 选择路径主要通过cfiledlg类来实现 // TODO: Add your control ...

  8. python中copytree的用法_python复制文件的方法实例详解

    本文实例讲述了python复制文件的方法.分享给大家供大家参考.具体分析如下: 这里涉及Python复制文件在实际操作方案中的实际应用以及Python复制文件 的相关代码说明,希望你会有所收获. Py ...

  9. Python 技术篇-用os库实现本地文件重命名实例演示

    os.rename() 就是用来重命名的. 下面演示将D:\python文件夹下的 a.txt 改为 b.txt. import os# 方法一 path = "D:\\python&quo ...

最新文章

  1. 第一学期网络技术知识总汇
  2. 看一遍就理解:MVCC原理详解
  3. C++实现学生成绩管理系统
  4. Visual C++6.0安装教程(win10版)及“应用程序无法正常启动(0x0150002)”解决办法
  5. android 手动 打包,android 手动打包apk
  6. JQuery UI 拖拽排序
  7. Android子线程更新UI的方法总结
  8. powershell 启动线程与关闭线程
  9. 【转载】回首大学四年,一个电工对大学课程的见解
  10. Luogu 3332 [ZJOI2013]K大数查询
  11. Zigbee之旅(五):几个重要的CC2430基础实验——串口通信
  12. linux临时目录不可查询,用find、rm命令清理Linux临时文件夹及检查Linux临时文件夹何时已满...
  13. python计算纪念日相关
  14. Linux 安装rabbitmq
  15. 抖音短视频运营借势热点:有哪些热点渠道,有哪些热点改编的套路。
  16. Leetcode 387. 字符串中的第一个唯一字符
  17. 强制结束进程的命令和软件
  18. SAP BP屏幕增强页签
  19. 41 ItemsWidget之QListWidget
  20. App中的HTML能在PC中运行吗,得到app电脑版有吗?得到app怎么在电脑上使用教程

热门文章

  1. 记录一下自己在区块链领域创业的经过
  2. VS2015 解决方案 或者项目 卡 正在加载 的解决办法
  3. PAT:1053. Path of Equal Weight (30) AC
  4. jQuery三级下拉菜单
  5. js获取时间(yyyy-MM-dd HH:mm:ss)
  6. 分布式架构的演进过程
  7. 3dContactPointAnnotationTool开发日志(二一)
  8. 软件分享:将应用一键打包成dmg文件
  9. Sequence在Oracle中的使用
  10. SQL Server 2008 R2——分组取前几名