安徽彩票大奖 欧洲百万乐透大奖 七星彩17049规律大奖 双色球中大奖领奖过程 3d近期中大奖故事 广州番禺中福彩大奖的 鸡男注定会中大奖 2016江苏彩民中大奖 趣彩网大奖网黑平台 大乐透4.97亿大奖 霍邱一彩民6元中双色球547万大奖 双色球黑龙江中大奖图 体育彩票中大奖名单 什么样的人能中大奖 彩票大奖作假

VBA 使用MADC的ADODB.Stream生成UTF-8文本文件(去掉BOM头)

2017-07-26 17:44:00
zstmtony
转贴
1230


VBA 使用MADC的ADODB.Stream生成UTF-8文本文件(去掉BOM头)


作者:masterjian


主要实现思路是使用 ADODB.Stream

主要关键代码如下:


Dim fsT As Object
Set fsT = CreateObject("ADODB.Stream")
fsT.Type = 2 'Specify stream type - we want To save text/string data.
fsT.Charset = "utf-8" 'Specify charset For the source text data.
fsT.Open 'Open the stream And write binary data To the object
fsT.WriteText "special characters: ??ü?"
fsT.SaveToFile sFileName, 2 'Save binary data To disk


前段时间,因为项目需要,需要用Excel管理国际化资源文件的?#22336;?#20018;,
旨在用VBA直接生成资源文件。

但是遇到一个问题,就是:

VBA生成的文本文件,默认是Gb2312编码(与系统的一致),所以我就
只能生成UTF-8格式的了。但是,用FSO生成的UTF格式是【UTF-16LE】
VS2008不识别。。。
郁闷之余,只能用MADC来生成。但是,情况又出现了,用MADC生成的UTF-8
文件默认是带BOM头的。。。

所以,逼上梁山的我就这能用下面的办法来实现UTF-8 无BOM头的写:

Private Sub WriteOut(strPath As String, str As String)

    Dim objStream As Object
    Set objStream = CreateObject("ADODB.Stream")
    
    With objStream
        .Type = 2               'adTypeText
        .Charset = "UTF-8"
        .Open
        .WriteText str
        .SaveToFile strPath, 2  'adSaveCreateOverWrite
    End With
    
    Set objStream = Nothing
End Sub


Public Function Convert2utf8(fileName As String, FileTo As String) As Boolean


    Dim ReadIntFileNum, WriteIntFileNum As Integer
    ReadIntFileNum = FreeFile() '获取一个空文件
    WriteIntFileNum = FreeFile() + 1
    
    
    Open fileName For Binary As ReadIntFileNum
    Open FileTo For Binary As #WriteIntFileNum
'    Dim byteFrom, byteTo As String
    Dim fileByte As Long
    Seek #ReadIntFileNum, 4
   
    While Not EOF(ReadIntFileNum)
    
        Get #ReadIntFileNum, , fileByte
        Put #WriteIntFileNum, , fileByte
    Wend
    
    Close #ReadIntFileNum
    Close #WriteIntFileNum
    Kill fileName
End Function


在使用的时候,先用WriteOut生成一个临时文件(UTF-8带BOM),
然后用Convert2utf8将BOM头的前三个字节删除。
分享
? 1999-2019 Office交流网?? 中山市天鸣科技发展有限公司 粤ICP备10043721号-5 SQL查询:19
内存占用:7.50MB
PHP 执行时间:0.15
双色球大奖2000年
安徽彩票大奖 欧洲百万乐透大奖 七星彩17049规律大奖 双色球中大奖领奖过程 3d近期中大奖故事 广州番禺中福彩大奖的 鸡男注定会中大奖 2016江苏彩民中大奖 趣彩网大奖网黑平台 大乐透4.97亿大奖 霍邱一彩民6元中双色球547万大奖 双色球黑龙江中大奖图 体育彩票中大奖名单 什么样的人能中大奖 彩票大奖作假
淘宝金皇冠和银皇冠 热带动物园走势图 吉祥8官网 pt古怪猴子规律 安徽25选5走势图 非常幸运 关颖 云贵川22选5走势图 街机捕鱼水果拉霸李逵捕鱼 神庙古墓怎么玩 欢乐生肖是什么彩