当前位置: 首页 > 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

相关文章:

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

这里使用了vba如下两个对象: Microsoft.XMLHTTP:文件读写,可读写二进制,可指定编码,对于utf-8编码文本文件使用FSO的TextStream对象打开,读取到的内容可能会出现乱码,可以使用该对象打开;前期绑定添加引用…...

MongoDB结合Robo 3T 1.4.3的简单操作

MongoDB的简单操作结合Robo 3T 1.4.3工具进行查询。 常用的正则表达式 /* 29 */ 正则表达式 /\* [0-9]* \*/ "_id" : ObjectId("5f3d05cdfd2aa9a8a7"), 正则表达式 \"([^\"]*_id)\".*, 使用方法:查询结果去掉注释和不需要…...

【学习笔记】[AGC048D] Pocky Game

这是一个非平等博弈。但是只要求你判断胜负,本身也不是一道结论题,所以可以用 D P DP DP来解决。 结论:第一堆石子剩的越多,先手玩家获胜的概率越大。这直接引出了一个非常感性的结论:每次取石子时要么取一堆&#xf…...

Qgis中进行Shp和Excel属性连接实现百强县公共预算空间分析

前言 在之前的博文中,将2022的全国百强县一般公共预算收入的数据下载到了本地,博客原文地址:一种使用Java的快速将Web中表格转换成Excel的方法。对于不关注时空位置关系的一般分析,到此也就基本够用了。但是,如果站在全…...

ES6 新增的循环方法

在 ES6(ECMAScript 2015)中,新增了一些循环方法,这些方法可以帮助我们更方便地遍历数组、字符串、Set、Map 等数据结构。本文将介绍一些常用的 ES6 循环方法。 for…of 循环 for…of 循环是一种遍历可迭代对象的方法&#xff0c…...

移动端事件300ms延迟解决

有移动端与PC端的项目开发,那么移动端和PC端开发上是存在差异的,比如 click 事件的300ms 延迟,即移动Web页面上的click事件响应都要慢上300ms,移动设备访问Web页面时往往需要 “双击” 或者 “捏开” 来放大页面看清页面的具体内容…...

NRF52832的DFU

开发环境: Winsodw:10 nRF5_SDK:17.1.0 1 工具安装 1.1 gcc-arm-none-eabi Downloads | GNU Arm Embedded Toolchain Downloads – Arm Developer 下载“gcc-arm-none-eabi-10.3-2021.10-win32.exe”,接提示安装。注意安装完…...

开源WebRTC库放大器模式在采集桌面图像时遇到的DPI缩放与内存泄漏问题排查

目录 1、在非100%的显示比例下放大器采集到的桌面图像不全问题 1.1、通过manifest文件禁止系统对软件进行缩放 1.2、调用SetThreadDpiAwarenessContext函数,禁止系统对目标线程中的窗口进行缩放 1.3、使用winver命令查看Windows的年月版本 2、使用放大器模式遇…...

敲黑板!java反射机制和原理

获取Class对象&#xff1a;首先&#xff0c;你需要获取表示要操作的类的Class对象。可以使用以下三种方式之一来获取Class对象&#xff1a; Class.forName()方法&#xff1a;使用类的全限定名获取Class对象&#xff0c;例如&#xff1a;Class<? Class<?> clazz MyC…...

【大数据工具】HBase 集群搭建与基本使用

HBase 集群搭建 HBase 安装包下载地址&#xff1a;https://archive.apache.org/dist/hbase/ 安装 HBase 的前提&#xff1a; ZooKeeper 集群 OKHadoop 集群 OK 1. HBase 集群安装 1. 将 HBase 软件包上传至 Hadoop0 解压并重命名 使用 FileZilla 将 hbase-1.3.1-bin.tar.g…...

【Java】数组详解

文章目录 一、数组的基本认识1.1 数组的概念1.2数组的创建与初始化1.3 数组的使用 二、数组的类型 — 引用类型2.1 JVM 内存分布2.2 什么是引用类型2.3 基本类型变量与引用类型变量的区别2.4 Java 中的 null 三、数组的应用3.1 保存数据3.2 函数参数3.3 函数返回值 一、数组的基…...

NumPy库的学习

本文主要记录的是笔者在B站自学Numpy库的学习笔记。 引入numpy库 import numpy as np矩阵的创建 创建一个二行三列的矩阵。 array np.array([[1,2,3],[2,3,4]])查看array的行数、形状、元素数量 print("number of dim:",array.ndim) print("shape:"…...

CentOS安装IRIS

最近电脑提搞了&#xff0c;可以无顾虑创建虚拟机了&#xff0c;试一下在Linux安装IRIS&#xff0c;适用CentOS7.6上安装Intersystem公司的IRIS数据库&#xff0c;资料基本是空白&#xff0c;分享一下。 首先安装解压软件unzip和libicu&#xff0c;最小化安装的缺&#xff0c;…...

华为OD机试真题 JavaScript 实现【最多几个直角三角形】【2023Q1 100分】

一、题目描述 有 N 条线段&#xff0c;长度分别为 a[1]-a[n]。 现要求你计算这 N 条线段最多可以组合成几个直角三角形&#xff0c;每条线段只能使用一次&#xff0c;每个三角形包含三条线段。 二、输入描述 第一行输入一个正整数 T (1< T< 100) &#xff0c;表示有…...

vue3中的reactive、ref、toRef和toRefs

目录 reactivereactive的实现原理使用reactive的注意事项 refref的实现原理使用ref的注意事项 toRef和toRefsref和reactive的使用比较 reactive reactive用于创建响应式对象&#xff0c;它返回一个对象的响应式代理。即&#xff1a;它返回的对象以及其中嵌套的对象都会通过 Pr…...

数字图像处理与Python实现-图像增强经典算法汇总

图像增强经典算法汇总 文章目录 图像增强经典算法汇总1、像素变换2、图像逆变换3、幂律变换4、对数变换5、图像均衡化6、对比度受限自适应直方图均衡(CLAHE)7、对比度拉伸8、Sigmoid校正9、局部对比度归一化10、总结本文将对图像增强经典算法做一个简单的汇总。图像增强的经典…...

tag提示词总结

顺序的权重 越靠前的tag权重越大&#xff0c;越靠后的tag权重越小经验来讲&#xff0c;将图像质量相关的tag放在前面&#xff0c;例如masterpiece&#xff0c;best quality等&#xff1b;接着添加主体画风等&#xff1b;最后添加一些不太重要的细节 权重增减 (tag)&#xff1a…...

微信小程序原生开发功能合集二十:导航栏、tabbar自定义及分包功能介绍

本章实现导航栏及tabbar的自定义处理的相关方法介绍及效果展示。   另外还提供小程序开发基础知识讲解课程,包括小程序开发基础知识、组件封装、常用接口组件使用及常用功能实现等内容,具体如下:    1. CSDN课程: https://edu.csdn.net/course/detail/37977    2. 5…...

高通 Camera HAL3:项目开发技术点总结

做高通 Camera HAL3开发的一些技术点的总结、整理。 做个记录&#xff0c;方便后续查阅。 1.目录、so、配置文件 productName是项目名 out Target路径&#xff1a;\out\target\product\productName\chi-cdk&#xff1a;\vendor\qcom\proprietary\chi-cdk\ldc node&#xff1…...

chatgpt赋能python:Python怎么删除列表中的最大值和最小值

Python怎么删除列表中的最大值和最小值 在Python中&#xff0c;一个列表&#xff08;List&#xff09;是一种非常常见的数据结构&#xff0c;它允许我们以有序的方式存储和访问数据。但是&#xff0c;有时候我们需要从列表中删除最大或最小的值&#xff0c;以满足我们的特定需…...

AI代理工具化新范式:基于MCP协议的模块化连接器实践

1. 项目概述&#xff1a;一个面向AI代理的模块化连接器最近在折腾AI应用开发&#xff0c;特别是围绕AI Agent&#xff08;智能体&#xff09;的生态构建时&#xff0c;发现一个挺普遍的问题&#xff1a;如何让这些Agent高效、安全地连接和使用外部工具与服务&#xff1f;无论是…...

BIOS里找不到SSD硬盘?Win10启动失败?可能是ESP引导分区‘隐身’了,手把手教你用PE盘和DiskGenius把它找回来

BIOS里找不到SSD硬盘&#xff1f;Win10启动失败&#xff1f;可能是ESP引导分区‘隐身’了 最近遇到一个奇怪的故障&#xff1a;明明SSD硬盘在PE系统里能正常识别&#xff0c;但BIOS启动项里却死活找不到它。系统反复提示"reboot and select proper boot device"&…...

从原理到实战:使用Kali Linux进行WiFi安全渗透测试

1. WiFi安全渗透测试基础 很多人可能觉得WiFi密码破解是个神秘的黑客技术&#xff0c;其实它只是网络安全领域中一个基础的安全测试手段。作为一名安全研究员&#xff0c;我经常需要在获得授权的情况下&#xff0c;对客户的无线网络进行安全评估。Kali Linux作为专业的渗透测试…...

终极泰坦之旅仓库管理指南:告别背包爆满,开启无限存储新时代

终极泰坦之旅仓库管理指南&#xff1a;告别背包爆满&#xff0c;开启无限存储新时代 【免费下载链接】TQVaultAE Extra bank space for Titan Quest Anniversary Edition 项目地址: https://gitcode.com/gh_mirrors/tq/TQVaultAE 你是否曾因《泰坦之旅》背包空间不足而忍…...

你的oh-my-zsh插件列表还缺它吗?深度体验autojump:不止是目录跳转

深度探索autojump&#xff1a;oh-my-zsh终端导航的智能记忆系统 终端操作效率一直是开发者关注的焦点。当你的命令行环境从基础功能升级到oh-my-zsh这样的强大框架后&#xff0c;如何进一步挖掘工具潜力成为提升工作流的关键。在众多效率插件中&#xff0c;autojump以其独特的&…...

从零到一:手把手教你为Nachos实现Exec和Exit系统调用(附完整代码与调试技巧)

从零构建Nachos系统调用&#xff1a;Exec与Exit的深度实现指南 1. 系统调用实现基础 在操作系统中&#xff0c;系统调用是用户程序与内核交互的唯一途径。Nachos作为一个教学用操作系统框架&#xff0c;其系统调用机制模拟了真实操作系统的核心设计思想。 寄存器交互机制是系统…...

三大核心突破:构建企业级实时图表编辑系统的架构演进

三大核心突破&#xff1a;构建企业级实时图表编辑系统的架构演进 【免费下载链接】mermaid-live-editor Edit, preview and share mermaid charts/diagrams. New implementation of the live editor. 项目地址: https://gitcode.com/GitHub_Trending/me/mermaid-live-editor …...

番茄小说下载器完整教程:如何轻松保存全网小说到本地

番茄小说下载器完整教程&#xff1a;如何轻松保存全网小说到本地 【免费下载链接】fanqienovel-downloader 下载番茄小说 项目地址: https://gitcode.com/gh_mirrors/fa/fanqienovel-downloader 想要永久保存番茄小说平台上的精彩作品吗&#xff1f;这款免费开源的番茄小…...

政府AI决策透明度如何影响公众信任?实证研究揭示关键机制

1. 项目概述&#xff1a;当算法成为“看不见的法官”在公共服务的数字化转型浪潮中&#xff0c;人工智能&#xff08;AI&#xff09;正从辅助工具演变为核心决策者。想象一下这样的场景&#xff1a;你提交了一份社会福利申请&#xff0c;原本需要数周的人工审核&#xff0c;现在…...

别再只盯着Modbus了!聊聊MBUS总线在智慧水务中的那些坑与最佳实践

MBUS总线在智慧水务中的实战指南&#xff1a;从协议解析到避坑实践 当智慧水务项目进入实施阶段&#xff0c;技术选型团队往往会陷入协议选择的困境。Modbus以其通用性成为首选&#xff0c;LoRa凭借无线优势占据一席之地&#xff0c;而MBUS&#xff08;Meter-Bus&#xff09;这…...