asp使用fso搜索字符串

   下面来试一试为web站点建立一个搜索功能。

   建立搜索引擎的关键是递归。主要地,编写一段代码搜索目录下的文件,然后对所有的目录循环执行同样的代码。因
为不能确定总共有多少个子目录,所以必须一遍又一遍地执行搜索代码,直到结束。递归调用非常好!

   下面来创建搜索页面。假设已经建立了一个HTML表单,用户在其中输入一个搜索字符串。

Dim objFolder
Dim strSearchText
Dim objFSO

strSearchText = Request.Form("SearchText") < -- The search string
' create the FSO and Folder objects
Set fso = Server.CreateObject("Scripting.FileSystemObject")
Set objFolder = objFSO.GetFolder(Server.MapPath("/"))

Search objFolder


   上面的代码简单地初始化变量,Search函数执行搜索功能,描述如下:



Function Search(objFolder)

 Dim objSubFolder



 'loop through every file in the current
folder

 For Each objFile in objFolder.Files

  Set objTextStream = objFSO.OpenTextFile(objFile.Path,1) < -- For Reading



    'read the file's contents into a
variable

    strFileContents = objTextStream.ReadAll



    'if the search string is in the file, then
write a link

    ' to the file

    If InStr(1, strFileContents, strSearchText, 1) then

      Response.Write "< A HREF=""/" & objFile.Name & _

        """>" & objFile.Name & "< /A>< BR>"



      bolFileFound = True

    End If



    objTextStream.Close



 Next



 'Here's the recursion part - for each

 ' subfolder in this directory, run the Search function again

 For Each objSubFolder in objFolder.SubFolders

    Search objSubFolder

 Next

End Function

   为了能打开文件,FSO需要实际的文件路径,而不是web路径。比如,是c:inetpubwwwroot empindex.html, 而不是
www.enfused.com/temp/index.html 或者 /temp/index.html。 为了将后者转换为前者,使用Server.MapPath
("filename"), filename表示web路径名。

   上面的代码将在你指定的初始目录下的文件夹的每一个子目录中执行,在这里,初始目录是指web根目录“/”。然后
就简单地打开目录下的每一个文件,看看其中是否包含指定的字符串,如果找到字符串就显示那个文件的链接。

   注意,随着文件和子目录数量的增加,搜索花费的时间也将增加。如果需要繁重的搜索工作,建议你采取其他的方
法,比如微软公司的索引服务器Index Server。

asp+txt 成绩查询系统 V3.8 这是个最简单易用却又最非常实用的查询系统。广泛用于成绩查询,工资查询,物业费查询,证书查询等地方,宾且页面适合手机、平板和电脑访问。 asp+txt 通用查询系统 v3.8 优势 它只有几kb大小,方便有能力修改的人快速修改为适合自己的查询。 它几乎都由你的txt文本数据库控制,只要维护好你的excel表格然后复制到文本文件然后更名即可。 它灵活支持多列多项目,而且各项目名称都可以由txt数据库控制。 它可以灵活运用到你的成绩查询,工资查询,物业费查询,证书查询等地方。 它比excel数据库还通用,excel的各个版本,wps表格,access数据库都可以快速转换。 它比excel的查询速度还快,他还比excel多一个绝对的优势,就是防止下载。 asp+txt 通用查询系统 v3.8 说明 解决部分用户不支持Response.Addheader而中文结果乱码问题。 操作界面比原来1.8更美观,结果使用table表格显示。 灵活支持2,3,4,...N列数据,你的excel文件是几列的,那就自动读取几列数据。 各项的标题(列头)由你的excel文件控制,无需改变程序的代码。 验证码验证,防止成绩信息及隐私被用列举的方法查询。 asp+txt 通用查询系统 v3.8 操作 打开excel或者wps表格或者access文件,选取数据范围,然后复制。 新建空白文本文件,粘贴,保存,更名(选项名称),改后缀(.dat)。 将新的文件用你常用的上传手段上传至网站数据库目录下。 注意原来表格的单元格内有回车换行会对查询有影响,请先替换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值