大家好,我们今日继续讲解VBA数组与字典解决方案,今日的内容是第21讲:如何将文本内容转化为数组。这个问题的提出是因为我们在处理一些文字时往往在WORD中,要拷贝到EXCEL中来填充一些资料,多是人名,设备名等,这些往往要求以独占一个 单元格的信息,这时该如何把这些人名,设备名放到EXCEL中呢?这就是文本转化为数组再填充的问题。

一:在处理字符串时可以使用Split 函数将字符串按指定的分隔符分开并以数组返回,

Split 函数返回一个下标从零开始的一维数组,包含指定数目的子字符串,语法如下:

Split(expression[, delimiter[, limit[, compare]]])

参数expression是必需的,包含子字符串和分隔符的字符串表达式。

参数delimiter是必须的,用来标识子字符串边界的字符串字符。如果忽略,则使用空格字符(" ")作为分隔符。

二:我们在完成数组的转换之后,往往要求横向或者纵向的填充,这时工作表Transpose函数返回转置单元格区域,即将一行单元格区域转置成一列单元格区域,反之亦然,语法如下:TRANSPOSE(array)

参数array为需要进行转置的数组或工作表中的单元格区域。

有了上面两个知识点我们看我们今日的学习内容,我们有一个单元格的文本内容,要把这些内容首先转化为数组,然后再填充到纵向的单元格中。代码如下:

Sub MySplitarr()

Dim Arr As Variant

Arr = Split(Sheets("21").Cells(1, 1), " ")

Sheets("21").Cells(3, 1).Resize(UBound(Arr) + 1, 1) = Application.Transpose(Arr)

End Sub

代码解析:

MySplitarr过程使用Split 函数将工作表Sheets("kk")中A1单元格的姓名分别写入到工作表Sheets("20")中的A列单元格。

第4行代码,首先使用UBound函数取得返回数组的最大下标后调整单元格区域,因为数组下标的缺省下界默认为0,所以在使用Resize属性调整单元格区域时参数RowSize需要在返回数组的最大下标上加1。

然后使用工作表Transpose函数将返回数组转置后写入到工作表调整后的单元格区域中。

代码截图:




hive json数组字符串转数组 hive字符串转化为数组_字节数组转换为图片


运行前的窗口:在A1单元格有一组文本:


hive json数组字符串转数组 hive字符串转化为数组_字符串转换为数组_02


运行后:


hive json数组字符串转数组 hive字符串转化为数组_字符串转换为数组_03


运行后在A3单元格向下处理了上述的文本。

今日内容回向:

1 Split 函数的作用是什么?他是VBA函数吗?

2 TRANSPOSE(array) 函数的作用是什么?