当前位置: 首页 > news >正文

VBA下载二进制文件,文本读写

这里使用了vba如下两个对象:

Microsoft.XMLHTTP:文件读写,可读写二进制,可指定编码,对于utf-8编码文本文件使用FSO的TextStream对象打开,读取到的内容可能会出现乱码,可以使用该对象打开;前期绑定添加引用:Microsoft ActiveX Data Objects 2.8

Microsoft.XMLHTTP:发送请求并获得返回,前期绑定添加:Microsoft XML v6.0

下载案例如下:下载火影忍者的图片到当前工作簿目录下
图片链接为:https://i0.hdslb.com/bfs/article/cb84523da172b11eb6222eb12f3c1737953f0359.jpg

Sub photo_download()
' 下载图片Dim X As Object
Dim ASTeam As Object
Dim content() As ByteSet X = CreateObject("Microsoft.XMLHTTP")
Set ASTeam = CreateObject("ADODB.Stream")With X.Open "get", "https://i0.hdslb.com/bfs/article/cb84523da172b11eb6222eb12f3c1737953f0359.jpg", False.sendDo Until .readystate = 4DoEventsLoopcontent = .responsebody   ' 请求返回对象
End With
With ASTeam.Type = 1 ' 二进制类型.Mode = 3 ' 可读可写.Open   '打开文件.write content    ' 文件写入.savetofile ThisWorkbook.Path & "/火影忍者.jpg"    ' 文件另存.Close   ' 关闭
End WithMsgBox "download done"
End Sub

关于ADODB.Stream的几个属性说明:

  • Type属性:读写文本文件用adTypeText(2),读写二进制文件用adTypeBinary(1)。
  • Mode属性:使用adModeReadWrite(3),可读写。
  • CharSet属性:指定文件编码,要根据文本文件的编码来设定。比如utf-8

如果使用后期绑定的方式,该属性只能通过枚举常量的等价数字定义,比如type的2表示读写文本文件

ADODB.Stream文本几个方法:
LoadFromFile:加载文本文件
ReadText:读取,ReadText(10)表示读取10个字符,不带数字表示读取文本剩余所有内容:ReadAll
close:同二进制文件,表示关闭对象,读写后关闭
WriteText:写入记录行,chr(10)表示换行
SaveToFile:保存为文本文件

文件读写样例

Sub file_read_write()
' 文本读写案例
' Dim ASteam As ADODB.Stream    ' 前期引用绑定,直接声明对象即可
Dim ASteam As Object
dim txt_path,s1,s2 as String Set ASteam = CreateObject("ADODB.Stream")    ' 创建对象
txt_path = ThisWorkbook.Path & "/文本文件.txt"     ' 文本文件路径
With ASteam' 文件写入.Type = 2  ' adTypeText   ' 指定类型.Mode = 3  ' adModeReadWrite  ' 可读写.Charset = "utf-8"  ' 指定编码格式.Open    ' 打开.WriteText "写入一行数据".WriteText Chr(10)   ' 写入换行符.WriteText "写入第二行数据".SaveToFile txt_path, adSaveCreateOverWrite ' 文件如果存在则覆盖' 文件读取.LoadFromFile (txt_path)s1 = .ReadText(3)s2 = .ReadTextDebug.Print s1, s2.Close
End WithEnd Sub
http://www.lryc.cn/news/92801.html

相关文章:

  • MongoDB结合Robo 3T 1.4.3的简单操作
  • 【学习笔记】[AGC048D] Pocky Game
  • Qgis中进行Shp和Excel属性连接实现百强县公共预算空间分析
  • ES6 新增的循环方法
  • 移动端事件300ms延迟解决
  • NRF52832的DFU
  • 开源WebRTC库放大器模式在采集桌面图像时遇到的DPI缩放与内存泄漏问题排查
  • 敲黑板!java反射机制和原理
  • 【大数据工具】HBase 集群搭建与基本使用
  • 【Java】数组详解
  • NumPy库的学习
  • CentOS安装IRIS
  • 华为OD机试真题 JavaScript 实现【最多几个直角三角形】【2023Q1 100分】
  • vue3中的reactive、ref、toRef和toRefs
  • 数字图像处理与Python实现-图像增强经典算法汇总
  • tag提示词总结
  • 微信小程序原生开发功能合集二十:导航栏、tabbar自定义及分包功能介绍
  • 高通 Camera HAL3:项目开发技术点总结
  • chatgpt赋能python:Python怎么删除列表中的最大值和最小值
  • 简述Vue的生命周期以及每个阶段做的事情
  • LeetCode-C#-0004.寻找两个正序数组的中位数
  • Vue.js 中的 $emit 和 $on 方法有什么区别?
  • LAZADA平台的商品评论Python封装API接口接入文档和参数说明
  • 云原生Docker镜像管理
  • ChatGPT+小红书的8种高级玩法
  • shell脚本学习记录1(运算符)
  • vector 迭代器失效问题
  • docker使用与服务器上的可视化(ROS rviz等)
  • 最新版本Portraiture4.1中文版ps磨皮滤镜插件安装包
  • 仓储WMS对接淘宝奇门详细说明【亲测可用】