转载--VBA学习笔记--数组和单元格互相转换--原文链接:https://www.cnblogs.com/Jacklovely/p/6606686.html

本文主要是介绍转载--VBA学习笔记--数组和单元格互相转换--原文链接:https://www.cnblogs.com/Jacklovely/p/6606686.html,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载--VBA学习笔记--数组和单元格互相转换

原文链接:https://www.cnblogs.com/Jacklovely/p/6606686.html

说明(2017.3.23):

1. VBA的数组还是很难用的,其实就是非常难用!

2. 要先定义一个数组,可以是空的,也可以里面写个数字作为数组长度。

3. 如果是空数组,可以后面redim重新定义数组长度。如果不是空的,再用redim就会报错“数组维数已定义”!

4. dim里面不能用变量,报错“只能用常数表达式”,里面只能用具体数字。

5. redim不能重新定义数组维数,就是说本来dim了一个一维数组,redim不能把它改成二维数组。

6. redim里面貌似能用变量。

7. 两种方法,一种定义一维数组,需要结果transpose转成行。另一种定义二维数组,结果直接写入单元格。

总结:

1. VBA的数组超级难用,用过的最难用的!

 

'第一种方法,定义一个一维数组,存放乘积,用transpose换成列后,写入单元格
Public Sub test()Dim arr()arr = Range("a7: b24")arrNum = UBound(arr)
'    如果arr2是个一维数组,后面要用transpose列转行Dim arr2()ReDim arr2(1 To UBound(arr, 1))For i = 1 To UBound(arr, 1)arr2(i) = arr(i, 1) * arr(i, 2)Next
'    resize从这个单元格往下数多少行,第二个参数是多少列
'    transpose把arr2的列转成行Range("e7").Resize(UBound(arr2), 1) = Application.Transpose(arr2)
End Sub
'第二种办法,定义一个二维数组,存放乘积,直接写入单元格
Public Sub test2()Dim arr()arr = Range("a7: b24")arrNum = UBound(arr)
'    如果arr2一开始就定义为二维数组,后面就不用转成行了Dim arr2(1 To 18, 1 To 1)
'    本来想用变量作为数组大小,不过好像不支持,redim也不能含有变量,而且不能重新定义二维数组
'    ReDim arr2(1 To 18,1 To 2)For i = 1 To UBound(arr, 1)arr2(i, 1) = arr(i, 1) * arr(i, 2)Next
'    resize从这个单元格往下数多少行,第二个参数是多少列Range("e7").Resize(UBound(arr2), 1) = arr2
End Sub

 

这篇关于转载--VBA学习笔记--数组和单元格互相转换--原文链接:https://www.cnblogs.com/Jacklovely/p/6606686.html的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

在React中引入Tailwind CSS的完整指南

《在React中引入TailwindCSS的完整指南》在现代前端开发中,使用UI库可以显著提高开发效率,TailwindCSS是一个功能类优先的CSS框架,本文将详细介绍如何在Reac... 目录前言一、Tailwind css 简介二、创建 React 项目使用 Create React App 创建项目

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换