VBA 读取sheet页中的指定区域数据,生成CSV文件

2024-05-03 23:04

本文主要是介绍VBA 读取sheet页中的指定区域数据,生成CSV文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

⏹待生成数据的sheet页

在这里插入图片描述

⏹VBA代码

  • CreateObject("ADODB.Stream"):Microsoft ActiveX Data Objects (ADO) 库中的一个对象,用来处理文件的读写操作。
  • Application.PathSeparator:系统默认的分隔符。
  • Const startRowNum = 4:定义一个常量
  • .SaveToFile FileName, SaveOptions
    • adSaveCreateNotExist(0):如果文件不存在,则创建文件并保存数据。
    • adSaveCreateOverWrite(2):如果文件存在,则覆盖现有文件并保存数据。
    • adSaveCreateNotExist(1):如果文件存在,则追加数据到文件末尾。
    • adSaveCreateOverWrite(4):如果文件存在,则在当前文件后面继续写入数据。
  • 换行符
    • vbCrLf:windows的换行符 \r\n
    • vbLf:Linux系统换行符 \n
Sub Csv_create()Dim fso As ObjectDim lineInfo As StringDim i As Long' ADODB.Stream 是 Microsoft ActiveX Data Objects (ADO) 库中的一个对象,用来处理文件的读写操作。Set fso = CreateObject("ADODB.Stream")' 获取要生成的文件的名称, Application.PathSeparator 表示系统默认的分隔符Dim fileName As String: fileName = ThisWorkbook.Path & Application.PathSeparator & Sheets("SHOP_INFO").Cells(1, 1).Value & ".csv"' 打开处理文件的流对象With fso.Charset = "UTF-8"' -1表示: 使用系统默认的分隔符.LineSeparator = -1.OpenEnd With' 定义一个常量,标识如果文件存在,则覆盖现有文件并保存数据。Const adSaveCreateOverWrite = 2' 开始的行号Const startRowNum = 4' 从"SHOP_INFO"工作表的 B2单元格 开始向下的连续非空单元格范围的最后一行' 定义变量的同时,给变量赋值Dim endRowNum As Integer: endRowNum = Sheets("SHOP_INFO").Cells(2, 2).End(xlDown).RowWith Sheets("SHOP_INFO").UsedRangeFor i = startRowNum To endRowNumlineInfo = ""lineInfo = lineInfo & """" & Sheets("SHOP_INFO").Cells(i, 2).Value & """" & ","lineInfo = lineInfo & """" & Sheets("SHOP_INFO").Cells(i, 3).Value & """" & ","lineInfo = lineInfo & """" & Sheets("SHOP_INFO").Cells(i, 4).Value & """" & ","lineInfo = lineInfo & """" & Sheets("SHOP_INFO").Cells(i, 5).Value & """" & ","lineInfo = lineInfo & """" & Sheets("SHOP_INFO").Cells(i, 6).Value & """"' vbCrLf: windows的换行符 \r\n' vbLf: Linux系统换行符 \nfso.WriteText lineInfo & vbLfNextEnd With' 保存文件fso.SaveToFile fileName, adSaveCreateOverWritefso.CloseSet fso = NothingMsgBox "csv文件创建完成!"End Sub

⏹生成的CSV文件

在这里插入图片描述

这篇关于VBA 读取sheet页中的指定区域数据,生成CSV文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/957848

相关文章

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

QT进行CSV文件初始化与读写操作

《QT进行CSV文件初始化与读写操作》这篇文章主要为大家详细介绍了在QT环境中如何进行CSV文件的初始化、写入和读取操作,本文为大家整理了相关的操作的多种方法,希望对大家有所帮助... 目录前言一、CSV文件初始化二、CSV写入三、CSV读取四、QT 逐行读取csv文件五、Qt如何将数据保存成CSV文件前言

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用