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

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

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

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

使用示例:
Call  WriteToTextFileADO(Sheets( " channel-list " ).Cells( 3 5 &   " \ "   &  feedName  &   " .xml " , feedXml,  " utf-8 " )

ADO方式读取

' 功能:读取text文件(ADO方式)
'
输入:输入文件地址、字符集
'
输出:无
Function  ReadFromFileADO(filePath  As   String , CharSet  As   String As   String
    
Dim  strRtn  As   String
    
Set  stm  =   New  ADODB.Stream
    stm.Type 
=   2   ' 以本模式读取
    stm.Mode  =   3
    stm.CharSet 
=  CharSet
    stm.Open
    stm.LoadFromFile filePath
    strRtn 
=  stm.ReadText
    stm.Close
    
Set  stm  =   Nothing
    ReadFromFileADO 
=  strRtn
End Function
目录
相关文章
|
8月前
csv 如果是utf-8 那么excel打开的时候为啥是乱码
csv 如果是utf-8 那么excel打开的时候为啥是乱码
174 0
|
Oracle 关系型数据库 Java
解决读取Oracle数据库US7ASCII编码乱码问题
今天和第三方对接数据时,对方提供了一个视图US7ASCII编码,给代码调试带来了很大的不便。程序输出的mybatis获取的对象及new String(s.getBytes("ISO8859-1"), "GB2312")加解密后都是乱码。
1415 1
|
7月前
|
存储 数据挖掘 数据处理
【解决 Excel 打开 UTF-8 编码 CSV 文件乱码的 BUG 】
【解决 Excel 打开 UTF-8 编码 CSV 文件乱码的 BUG 】
343 0
|
3月前
|
C语言 C++
01 按指定格式读写文件出现乱码
##按指定格式写文件使用stringstream
22 0
|
8月前
将ansi文本格式以utf-8文本格式进行读取
查阅网上很多博客关于其他文本格式转化成utf-8,会出现中文乱码的情况,自己也遇到了,看到网上很多乱七八糟的博客,都没有什么实质性的解决方案。为此专门写了这篇博客,希望能对你们有帮助。
53 0
【文档操作】文本文件转excel文件
Excel文件是我们常用的一种文件,在工作中使用非常频繁。Excel中有许多强大工具,因此用Excel来处理文件会给我们带来很多便捷。但是有时候我们拿到了文件不是Excel文件,而且我们又想用Excel中的工具,这个时候我们就可以想办法把这个文件转换成Excel文件了。今天我们就来实现一下,需要注意我们只能把有规律的文件转换成Excel,而且今天的内容也不是普遍通用的。只提供一种思路。
117 0
|
文件存储 Python
文本文件的编码格式
文本文件的编码格式
161 0
C#编程-35:写入读取文本文件
C#编程-35:写入读取文本文件
|
Linux Windows JavaScript
csv文件乱码
问题描述: 生成的csv文件,设置为UTF-8格式,在windows上用EXCEL打开的话会乱码,在linux上用vim或者cat打开查看正常;设置为GBK格式的话,在windows上用EXCEL打开正常,但在linux上乱码   解决方法: 在csv文件头部的最前面加bom   BOM(Byte Order Mark),是 UTF编码方案里用于标识编码的标准标记,在 UTF-16里本来是 FF FE,变成 UTF-8就成了 EF BB BF。
1294 0