|
本帖最后由 muyuzhth0 于 2023-2-4 15:04 编辑
9 H2 f; I/ `# t$ A3 z
8 s5 n5 U6 }0 x ~$ N一、前言1 v/ q/ ? B( ]8 G! U( c) I# `; m
本人使用mdict、goldendict多年,自己也做过一些词库,目前还在使用goldendict,受益颇多。这两款词典的优点很多,我也就不多说了,但是仍然满足不了我的一些需求。1 k) W! J6 c" T
本人收集了很多很多很多pdf、word文档资料。如何在这些资料中快速找到自己需要的信息呢?! Q. w# @+ l. V7 k$ N9 M8 p
例如:在3万多文件中,全文搜索“表见代理”,找到427个文件,在这427个文件范围内全文搜索“除斥期间”,找到21个文件,在这个21个文件中全文搜索“起算”……
' q" q# ]/ W8 Y" M' I4 _7 ymdict、goldendict难以胜任这个工作。全文搜索工具有好多,不乏Archivarius 3000、anyTXT等神器,不过各有优缺点(全文搜索工具对比介绍),也不能满足我的需求。3 c" j% _0 S3 V' X1 Y
以前写过简单的程序用来搜索pdf或者word文档。但是程序会有一个提取pdf(word、excel)文档字符的过程,并且每次搜索都要重新提取。这个过程非常耗时,于是放弃了。
1 [& k$ u# O0 _2 `! j' \* N因为不会制作索引,又因为我的资料库几乎每天都在增加新内容,所以本人这次采取的方式是将资料库中的pdf(word、excel)文档转换为txt格式的文档(可能相当于山寨版的索引吧),然后在txt文档中搜索需要的信息。如果检索到,则说明相同文件名的pdf(word、excel)文档中有相同的信息,配合“everything”神器,打开查阅即可。
" P [, U& ?: i( Y二、搜索效率测试
9 D0 D2 R6 D) `- \仅支持64位windows系统,在win7、win10上测试过,可用,未报错。: Y; F, ?# k P" X5 }* q9 L
2 p/ p1 D. r6 ^$ g1 G3 ~- |程序和文档全部在u盘里,3.2万+个文档。
5 p+ u! S2 z% c4 Q' N$ y: U8 q# l7 \. D" x6 @, G" _
使用regex搜索“.{0,50}表见代理.{0,50}”,耗时70.44秒。8 T7 Z( N. \; k" o v* y( |
6 v; }+ t% `% B% _" Q1 l: P
不使用regex搜索“表见代理”,耗时29.12秒。. G/ Q# `) {& I! p( R& B' K
1 ^3 Z' y5 A+ Q+ }5 s三、程序主要特色
* Y6 L" M6 g. U( w+ `9 j* f' J1.支持在搜索结果范围内继续搜索,不断缩小搜索范围。
# I6 m" }8 H' F5 i" W; `2.支持文件名和文件全文两个关键词的同时匹配。
8 l7 z! h1 }' e8 T3.支持正则表达式或非正则表达式两种搜索模式。使用正则表达式时,支持显示详细信息。! @' F( `( y/ V- O5 v* v
4.支持搜索记录导出。; R' N$ u# J, m a5 O
5.根据需求,手动转换所需文件转换为txt文档,不强制建立索引文件。8 d+ W. [/ N0 @7 M
好了,如果你有相似使用情形,且对搜索效率满意,也没有什么更好的其他软件可选择(如果有,告诉我),那么接着往下看。# d) i/ E+ X: T$ J8 W6 _
四、功能介绍( P9 e# w, B5 n. |
. R& @: ?& s4 l5 O; L* C( irootdir:点击这个button,选择搜索的路径(包括子目录中的文档)。
+ J9 `! Z$ E: K t) Nkeyword(in filename):设置搜索文件名中的关键字。这一步速度超快,如果知道文件名中的必包含的关键字,设置后会缩小文档搜索的数量。设置为“txt”表示在所有txt文档中搜索,因为每个txt文档的文件名都包含“txt”,当然也可以设置为空。
9 T3 L9 H- R$ `$ A' |4 _* t4 Zkeyword(in txt):设置搜索txt文档内容中的关键字。( B3 `" G! g0 w( n' t0 z
use regex(details):是否使用正则表达式搜索(使用正则表达式搜索,支持显示搜索到的详细信息)。; v0 y7 m u3 [9 e; ~+ f" w5 S
绿色进度条:显示程序转换txt或搜索进度。
4 S- ?' a5 w7 y6 i jconvert to txt:将选择的路径下的所有pdf(word、excel)文档转换为txt(编码:utf-8-sig)文档,并保存在相同路径下。支持*.pdf、*.doc、*.docx、*.xls、*.xlsx格式,文档中的图片内容无法提取。首次使用或者文档有增加、修改时,需要使用此功能。转换效率测试:335个文件,耗时290.41秒。' U4 q4 s3 k. V1 m. M/ w
search in rootdir:顾名思义,点击这个button,每次都会在搜索路径下检索信息。例如:选择某个目录,包含3.2万+txt文档,搜索“表见代理”,找到427个文档。如果换其他关键词搜索,搜索范围仍然是目录下的3.2万+文档。; i# T( R/ q$ F( F& P- l
search in results:点击这个button,每次将在上一次检索到的文档范围内搜索,搜索后不缩小搜索范围。接上例,想在这427个文档中找包含“最高法”或者“最高人民法院”或者其他关键词的文档,首先搜索“最高法”,点击“search in results”,找到0个,那么再试试输入“最高人民法院”, 点击“search in results”,程序仍然会在427个文档的范围内搜索,如果没找到,可以再换其他的关键词……
' d, s/ s( d/ K- s( c# j4 D9 Vsearch recursively:点击这个button,用来确认、缩小搜索范围。接上例:在427个文档中搜索到50个包含“最高人民法院”的文档,如果想在这个50个文档的范围内搜索其他关键词,先点击“search recursively”后,程序会修改搜索范围至这50个文档,接下来再使用“search in results”尝试搜索“驳回”、“除斥期间”等不同的关键词,找到想要的文档范围后,再点击“search recursively”来确认缩小搜索范围……两个button循环使用,直到找到符合要求的结果。) f& ^! o2 x- n# e3 x8 Z. s4 @7 z
貌似逻辑运算或者正则表达式也能够实现这个搜索目的,但是这么搜索逻辑上更简单,搜索结果也更清晰,细品,还是有不少区别的。2 |# g- R) u+ X! s% c; s3 p. G+ z, Y
可能你还不明白……不要紧,我表达能力有问题,一共没有几个button,结合需求,稍微试试就知道他们的区别了。 p) K/ p, d2 f) {& T; c
中间显示区:显示程序运行信息。
9 w [$ U" `# P' l3 `3 g; ^底部提示:不使用正则表达式或使用正则表达式时关键字用法和示例的简单介绍。
4 O7 N, @, P1 Z# f5 _, s: C. [* ]& T" D+ l* R
|
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?免费注册
x
评分
-
2
查看全部评分
-
|