saintom 发表于 2004-1-14 18:42:12

简介对文件操作的组件


在以前的IIS版本中,你会感到对文件操作的限制有些过分,你只能读写一些文本文件,这种限制对于熟练的程序员是很难受的,例如,无法直接得到诸如一个文件是否存在的信息。

幸好,IIS4.0版已经令人激动的将这种局面进行了改变。在这个版本的Active Server Pages中有很多组方法、属性、集合来对文件进行操作处理。利用Active Server Pages脚本,你就几乎完全可以控制服务器的文件系统。

作到这些,需要如下的组件:

·FileSystemObject:这个对象包括了一些基本的对文件系统进行操作的方法,比如说,复制和删除文件夹或者文件

·TextStream:这个对象用来读写文件

·File:它的方法和属性被用来处理单独的文件。

·Folder:它的方法和属性被用来处理文件夹。

在读完后面部分后,你会明白这些具体操作过程是怎样进行的,那么如果希望了解全部的有关集合、属性和方法列表,参见本书附录A的有关部分。

在一个文件中读写数据

这部分介绍如何读写一个文本文件。这对文本文件有很多用处,包括下面这些。

·一个常用的日志,利用文本文件记录访问者的活动以供日后参考。你可以记录诸如访问者IP地址,浏览器类型等等你能得到而且想要了解的东西。

·Form中的数据,你可以将用户在Form的文本框中填写的东西记入文本文件,尽管使用数据库会更加有效。

·每日新闻,将每日的新消息记录到文本文件,然后可以在很多文件中读出来显示

对文本文件的写操作

要创建并且写入一个文本文件,你应当使用FileSystemObject和TextStream对象。首先,你需要创建一个FileSystemObject对象的事例,然后,再利用CreateTextFile()以该事例创建一个TextStream对象的事例,最后利用TextStream对象的WriteLine()方法来写入文件。下面是这个例子:

<%

Set MyFileObject=Server.CreateObject(“Scripting.FileSystemObject”)

Set MyTextFile=MyFileObject.CreateTextFile(“c:\mydir\test.txt”)

MyTextFile.WriteLine(“欢迎进入xxx网络ASP教程文件操作示例!”

MytextFile.Close

%>

这个例子创建了一个名字为test.txt的文件,该文件位于c:\mydir\,WriteLine()方法被用来将那一句话写入该文件。最后,这个TextStream对象的事例关闭并且释放所有资源,下面部分将对每一个步骤进行仔细解释。

注:如果你需要虚拟路径转化为真实路径(这样操作使得站点具有更强的可移植性),可以用Server.MapPath()方法,例如下面这个例子:

PhysicalPath=Server.MapPath(“/private/test.txt”)

假设虚拟路径/private对应于真实路径c:\net\private,那么这个PhysicalPath的值将是c:\net\private\test.txt

CreateTextFile()方法用来创建一个新的文本文件,当这个方法被调用,那么就返回一个TextStream对象,这个方法有一个必须的参数和两个可选的参数。

·FileSpecifier,限定要创建的文件及路径,如果没有这个参数,显然是要报错的。

·Overwrite,这个参数是可选的,默认为TRUE,如果存在同名的文件,依据这个参数判断是否进行覆盖操作,如果赋为FALSE,那么存在同名文件时会返回错误信息。

·Unicode,这个参数可选,默认为False,指示该文件是否用ASC码形式进行创建和保存。如果选择TRUE,将以Unicode方式创建。

再利用CreateTextFile()方法创建了文本文件后,你就可以使用TextStream对象来对文件进行读写,在写操作时,有如下的方法:

·Write(String).这个方法将一个字段写入文本文件。

·WriteLine(String),这个方法是在文件中添加字串和一个分行符,这里面的string参数可选,如果没有的话,则添加一个分行符。

·WriteBlankLines(lines),顾名思义,这是允许用户在文件中指定数目个分行符。

·close.这个方法就是关闭一个打开的TextStream文件并释放其占用的资源。

下面是一个连续在文件中输出32行同样字符串的例子脚本:

<%

Set MyFileObject=Server.CreateObject(“Scripting.FileSystemObject”)

Set MyTextFile=MyFileObject.CreateTextFile(“c:\mydir\test.txt”)

For i=1 to 32

    MyTextFile.WriteLine(“Hello World!”)

Next

MyTextFile.Close

%>

在文本文件中读取和追加数据

这里,首先要做的依然是创建一个FileSystemObject对象的事例,然后,利用OpenTextFile()方法来创建一个TextStream对象的事例,最后,你就可以用TextStream对象的ReadLine方法来对文件读取,下面是个例子:

<%

Set MyFileObject=Server.CreateObject(“Scripting.FileSystemObject”)

Set MyTextFile=MyFileObject.OpenTextFile(“c:\mydir\test.txt”)

While not MyTextFile.AtEndOfStream

   Response.Write(MyTextFile.ReadLine)

Wend

MyTextFile.Close

%>

这个脚本将文本文件Test.txt文件中所有的内容读出来并且显示在浏览器上。如果文件不存在,回显示相应错误信息(在下一个部分,你会学到怎样检测一个文件是否存在)

其中While…Wend循环是将文件内容一行一行的循环读取,其中如果没有到达文件末尾,那么AtEndOfStream属性就会是False,直到末尾时变为True。

下面是读取文件时可能会用到的属性:

·AtEndOfLine。这个属性判断是否到了文件中一个特定行的末尾,如果不是,则为False,反之为True

·AtEndOfStream。就是这个例子中用到的,判断是否到了该文件的结尾并依此返回True和False

·Column。这个属性判断当前字符在该行的位置,返回一个整数值。

·Line。这个属性判断当前行在文件中的行数,返回一个整数值

除了使用ReadLine方法以外,你当然还可以使用Read()方法。Read()方法会从指定打开的文本文件中返回指定数目个字符。下面是用这个方法的示例:

<%

Set MyFileObject=Server.CreateObject(“Scripting.FileSystemObject”)

Set MyTextFile=MyFileObject.OpenTextFile(“c:\mydir\test.txt”)

While NOT MyTextFile.AtEndOfLine

   Response.Write(MyTextFile.Read(1))

WEND

MyTextFile.Close

%>

这个脚本从文本文件中接受第一行,每次接受显示一个字符,利用AtEndOfLine属性一直到行尾截止,由Read(1)一个一个读取。

下面是从文本文件读取数据时要用到的方法

·Read(Number).从文本文件中读取限定数目个字符

·ReadLine.从文本文件中读取一行(换行符不返回)

·ReadAll.这个方法接受TextStream文件的所有内容

·Skip(Number).这个方法从一个打开的文本文件中跳过指定数目个字符

·close关闭当前打开的文件并释放所占用的资源。

一般说来,OpenTextFile()方法是用来读取数据的,但是你也可以用它追加数据信息,例如,你希望在该文本数据中追加一些新内容,可以见下面的示例:

<%

Set MyFileObject=Server.CreateObject(“Scripting.FileSystemObject”)

Set MyTextFile=MyFileObject.OpenTextFile(“c:\mydir\browser.log”,8,TRUE)

MyTextFile.WriteLine(Request.ServerVariables(“HTTP_USER_AGENT”))

MyTextFile.Close

%>

这个脚本用于在网站中创建一个日志文件。无论什么时候这个脚本执行,此时的浏览器类型就会追加到该日志文件中,浏览器信息由ServerVariables集合接收。

注:有关ServerVariables集合的情况参见本书的第14章有关小节

这里面需要说明的是,如果browser.log不存在,则会自动建立,这是使用了OpenTextFile()方法的两个参数:IOMode和Create参数。

下面介绍针对于OpenTextFile()方法的所有参数:

·FileSpecifier,限定要进行读写或者追加的文本文件名称

·IOMODE,可选参数,指示该文件是被用来读,写还是追加。默认为1表示读,设为2表示进行写操作,进行追加操作则设为8。

·Create,可选参数,如果文件不存在是否创建,默认为False,如果希望进行创建,则设为TRUE

·Format,可选参数,指示文件是ASCII码制格式还是Unicode格式,作为默认的ASCII码制文件,其值为-2,如果希望设为Unicode格式,此参数设为-1

你不能在当前版本的Active Server Pages中使用常量,例如,你如果希望进行文件 追加,你必须使用数字8作为参数而不是什么常量。




页: [1]
查看完整版本: 简介对文件操作的组件