VBA生成或读取指定字符集的文本文件

用VBA做工具的过程中,遇见这样一个问题。使用FSO方式或者直接OPEN文件方式,生成的文本文件采用的字符集为当前操作系统默认字符集,不能选择字符集类型。这样的文件作为应用程序的配置文件或者作为js代码文件,常常会因为字符集不是UTF-8,不能直接使用,需要利用记事本进行一次人工的字符集转换。特别麻烦。

近日发现有一办法,可以较好的解决这个问题。即是采用ADO的方式,将字符串生成以指定字符集的流文件输出。
函数代码如下,VB或VBA中均可用。注意:需要添加对ADO 对象库的引用。

ADO方式写入
VBA生成或读取指定字符集的文本文件'功能:text保存为文件(ADO方式)
VBA生成或读取指定字符集的文本文件'
输入:输出文件地址、内容文本、字符集
VBA生成或读取指定字符集的文本文件'
输出:无
VBA生成或读取指定字符集的文本文件
Sub WriteToTextFileADO(filePath As String, strContent As String, CharSet As String)
VBA生成或读取指定字符集的文本文件    
Set stm = New ADODB.Stream
VBA生成或读取指定字符集的文本文件    stm.Type 
= 2 '以本模式读取
VBA生成或读取指定字符集的文本文件
    stm.Mode = 3
VBA生成或读取指定字符集的文本文件    stm.CharSet 
= CharSet
VBA生成或读取指定字符集的文本文件    stm.Open
VBA生成或读取指定字符集的文本文件    stm.WriteText strContent
VBA生成或读取指定字符集的文本文件    
'如果文件存在,删除文件
VBA生成或读取指定字符集的文本文件
    If Len(Dir(filePath)) > 0 Then
VBA生成或读取指定字符集的文本文件        Kill filePath
VBA生成或读取指定字符集的文本文件    
End If
VBA生成或读取指定字符集的文本文件    stm.SaveToFile filePath, 
2
VBA生成或读取指定字符集的文本文件    stm.Flush
VBA生成或读取指定字符集的文本文件    stm.Close
VBA生成或读取指定字符集的文本文件    
Set stm = Nothing
VBA生成或读取指定字符集的文本文件
End Sub

使用示例:
VBA生成或读取指定字符集的文本文件Call WriteToTextFileADO(Sheets("channel-list").Cells(35& "\" & feedName & ".xml", feedXml, "utf-8")

ADO方式读取

VBA生成或读取指定字符集的文本文件'功能:读取text文件(ADO方式)
VBA生成或读取指定字符集的文本文件'
输入:输入文件地址、字符集
VBA生成或读取指定字符集的文本文件'
输出:无
VBA生成或读取指定字符集的文本文件
Function ReadFromFileADO(filePath As String, CharSet As StringAs String
VBA生成或读取指定字符集的文本文件    
Dim strRtn As String
VBA生成或读取指定字符集的文本文件    
Set stm = New ADODB.Stream
VBA生成或读取指定字符集的文本文件    stm.Type 
= 2 '以本模式读取
VBA生成或读取指定字符集的文本文件
    stm.Mode = 3
VBA生成或读取指定字符集的文本文件    stm.CharSet 
= CharSet
VBA生成或读取指定字符集的文本文件    stm.Open
VBA生成或读取指定字符集的文本文件    stm.LoadFromFile filePath
VBA生成或读取指定字符集的文本文件    strRtn 
= stm.ReadText
VBA生成或读取指定字符集的文本文件    stm.Close
VBA生成或读取指定字符集的文本文件    
Set stm = Nothing
VBA生成或读取指定字符集的文本文件    ReadFromFileADO 
= strRtn
VBA生成或读取指定字符集的文本文件
End Function
VBA生成或读取指定字符集的文本文件
上一篇:[Head First设计模式]身边的设计模式——适配器模式


下一篇:选择WordPress 主机空间需要注意什么?