当前位置: 首页 > 图文教程 > 脚本技术 > VBScript > 用VBScript写合并文本文件的脚本

VBScript
tel.xls.vbs xls专杀工具
病毒专杀VBS模块
用vbs实现的一款Worm.Win32.VB.fw病毒专杀
VBScript提交表单提示-对象不支持此属性或方法
Windows Script Host之用vbs实现[浏览文件夹]功能
定时自动备份IIS的WWW日志的vbs脚本
可以将Bat转换位VBS文件的VBS脚本
用vbs实现cmd功能
VBS编程教程 (第1篇)
VBS编程教程 (第2篇)
VBS编程教程 (第3篇)
VBS编程教程 (第4篇)
VBS编程教程 (第5篇)
VBS编程教程 (第6篇)
用VBS可执行程序+Xmlhttp下载备份网上文件的代码
注册表-批处理-VBS之间的相互结合应用
用vbs实现显示系统调色板的代码
用vbs遍历文件并随机显示的脚本
用vbs实现随机读取文件的一行内容的脚本
用vbs实现读取文本文件的方法

用VBScript写合并文本文件的脚本


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 242 ::
收藏到网摘: n/a

合并文本的脚本可以这么写:
复制代码 代码如下:

Sub AppendTextFile(filename)
Set objTextFile = objFSO.OpenTextFile(filename, ForReading, true, -2)
Do Until objTextFile.AtEndOfStream
objOutFile.WriteLine(objTextFile.Readline)
Loop
End Sub

可是如果所读取的文件是UTF-8格式的,那么文件开头的三个字节的标识符会被脚本认为是数据,这样这个标识符就变成了合并后文件里的乱码。
FSO是提供了打开Unicode文件的参数的,可惜这里并不生效。

TristateUseDefault

-2

Opens the file using the system default.

TristateTrue

-1

Opens the file as Unicode.

TristateFalse

0

Opens the file as ASCII.

请教了Google大师,发现有人说用OpenAsTextStream是可以的,可惜在我的环境里还是不成功。
另外一个想法是读入文件的时候,自行判断文件开始三个字节是否标识符,这也被判断是不可行的方法,因为FSO提供的Read是按字符进行读取,这样,在有中文的环境里,我们不可能正好读出这三个字节。
类似的问题在IIS6里面被微软确认,好像也有一个对应的补丁出来,但是对于批处理文件的情况,似乎还是没有修改过来。
最后,MSDN帮了很大的忙,但是它的地址很不好找,记录一下:
http://msdn.microsoft.com/en-us/library/ms950396.aspx