如何快速将多列数据转换成多行数据
发布时间:2022-11-07 02:28:38
在我的工作表中,同一行是某学生测试项目和课外兴趣班的全部信息,如下图1所示。
图1:在工作表“InputData”列A至列C中存储学生一般信息,列D至列列W存储着学生测试项目信息。测试项目信息分为“测试项目、测试日期、分数、等级”列,共重复5次(即有5个测试项目)。
图2:在工作表“InputData”列X至列AI存储着学生课外兴趣班信息。课外兴趣班信息分为“课外兴趣班、频次、持续时间、效果”列,共重复了3次。
现在,要将工作表“InputData”同一行中的数据转换成多行数据,并存储到工作表“OutputData”中,如下图3所示。
图3:转换成多行数据的结果。每名学生的“测试项目、测试日期、分数、等级”和“课外兴趣班、频次、持续时间、效果”信息放置在不同的行中。
可以使用VBA代码来快速完成数据的转换:
‘设置数组下标从1开始
Option Base 1
‘自定义类型
Type student
info() As Variant
exam(5) As Variant
interest(5) As Variant
End Type
Sub MainOutput()
Dim wks As Worksheet
Dim i As Long
Dim rngInputData As Range
‘获取要处理的数据区域
Set rngInputData =Worksheets(“InputData”).Range(“A1”).CurrentRegion
Set rngInputData = rngInputData.Offset(1,0). _
Resize(rngInputData.Rows.Count – 1,rngInputData.Columns.Count)
‘调用OutputData过程处理数据
OutputData rngInputData,Worksheets(“OutputData”).Range(“A2”)
‘自动调整列宽
Worksheets(“OutputData”).Range(“A1”).CurrentRegion.Columns.AutoFit
End Sub
Sub OutputData(rngSource AsRange, rngTarget As Range)
Dim titles() As Variant
Dim inputRows As Long
Dim i As Long
Dim j As Long
Dim k As Long
Dim stu() As student
‘输出表标题
titles = Array(“编号”, “姓名”, “性别”, _
“测试项目”, “测试日期”, “分数”, “等级”, _
“课外兴趣班”, “频次”, “持续时间”, “效果”)
‘获取输入数据行数并定义数组大小
inputRows = rngSource.Rows.Count
ReDim stu(inputRows)
‘遍历输入数据
For i = 1 To inputRows
‘依次将相应数据存放在数组中
With stu(i)
k = 4
‘存储前3列数据
.info = Range(rngSource.Item(i, 1),rngSource.Item(i, 3))
‘存储后面重复标题相应的数据
For j = 1 To 5
.exam(j) =Range(rngSource.Item(i, k), rngSource.Item(i, k + 3)).Value
.interest(j) =Range(rngSource.Item(i, k + 20), rngSource.Item(i, k + 23)).Value
k = k + 4
Next j
End With
Next i
‘清空放置数据的工作表
rngTarget.CurrentRegion.ClearContents
‘输入标题
rngTarget.Offset(-1, 0).Resize(1, 11).Value= titles
k = -1
‘输入数据
For i = 1 To inputRows
For j = 1 To 5
With stu(i)
If .exam(j)(1, 1) <>”” Or .interest(j)(1, 1) <> “” Then
k = k + 1
rngTarget.Offset(k,0).Resize(1, 3).Value = .info
rngTarget.Offset(k,3).Resize(1, 4).Value = .exam(j)
rngTarget.Offset(k, 7).Resize(1,4).Value = .interest(j)
Else
Exit For
End If
End With
Next j
Next i
End Sub
上述代码中使用了一些注释,方便阅读和理解。要说明的是,代码使用了自定义类型,很清楚地存储不同用途的数据,并能够很方便地调用,这是一个很好的技巧。
此外,本示例再次表明,针对特定的数据整理需求,使用一些VBA代码,就可快速达到目的,省去了重复操作的繁杂和易出错的烦恼。


猜你喜欢
- 大家在Windows应用商店下载软件时,有遇到错误代码0x803fb005的情况吗?即使重新启动Windows应用商店问题依然存在,Win1
- 没有及时保存的后果就是之前写的文字全部作废了,一切都得重头再来,所以我们要学会让系统自己每隔几分钟就自动保存文档,一起来了解一下吧当我们在写
- wps中插入图片以后,想要修改一下图片。修图软件都是用在那些复杂的图片上的,简单的我们可以直接在WPS文字上面改动,既省时间又方便操作。以下
- 上学的时候,经常看的就是课程表,当时还自己抄了一份放在自己桌子上,现在有了电脑,不用用手抄了,但是怎么才能用WPS做一个课程表呢对于新手来说
- 当今大家处于大数据的时代,一些个人隐私问题就会通过平时不经意的瞬间泄露,最近很多用户想要注销石墨文档的账号,但是就是不知道具体的操作方法,没
- 其实一直以来被我们忽略的某些技巧,有时候非常实用~今天,就来为大家分享几个Word中比较实用的隐藏技巧
- 在Win7系统中存放的文件过多,情急之下要找文件却想不去文件名怎么办?今天小编就教大家用文件内容进行搜索文件,感兴趣的小伙伴快来看看方法技巧
- Win10专业版玩游戏总是闪退怎么办?许多用户使用电脑多多少少都会在闲暇的时间玩游戏放松一下,可是最近有用户反映自己在玩LOL和CSGO游戏
- 在电脑中,管理磁盘分区是一件非常重要的事,尤其是对空间的合理分配,如果分配的空间不合适的话,可能就会导致磁盘空间不够用等问题出现。所以对于这
- win11右键刷新怎么改回来?Win11系统是现在非常火热的电脑操作系统,全新的功能与界面让很多用户都非常不适应,而且取消了Win11右键菜
- 任何一款软件在使用的过程中都无法保证不会出现问题,因此反馈渠道就显得十分重要了。那么,如果智能办公软件钉钉在使用中出现了问题,该怎么反馈呢?
- 这个问题放大点说就是如何去掉某一页的页眉,下面我们来看看吧:用WPS打开要处理的文档,选择想要处理的页面,就是将
- Excel是一个办公很经常用到的一个办公软件,他主要用于数据的分析、查看、对比等,让数据看起来更直观,更容易对比,而掌握一些有关于Excel
- 在升级或者安装Windows10的时候 无论保留数据还是不保留数据安装都提示这个错误:无法安装 Windows 10,已将你的电脑设置回开始
- 当我们准备给文件压缩的时候,发现右键菜单中没有压缩文件选项了,这是怎么回事呢?遇到这种情况应该怎么解决呢,接下来就为大家带来解决方法,有需要
- 最近一些Win7 64位 系统用户在输入密码登录时,发现电脑变成黑屏了。这个问题该怎么修复呢?其实方法很简单,现在小编就来教你怎么操作。推荐
- 左边图片的效果怎么实现呢?是不是需要对照片进行精致的“拆分”成方块后,在拼叠在一起呢?拆分确实是一种方法,但制作的效率太低,太耗费时间!其实
- 视图——网格和参考线,在出现的那个界面除了第一个打钩的不删除其他的都去掉选择。具体步骤:①启动PowerPoint2010,我们先调出参考线
- 小伙伴们,小伙伴今天给你们带来了一个非常棒的技能哟。小编猜你们一定非常想知道是什么吧!其实呢,小编今天给你们带来的这个技能就是进行修改系统时
- raw格式是什么意思?RAW的原意就是“未经加工”。可以理解为:RAW图像就是CMOS或者CCD图像感应器将捕捉到的光源信号转化为数字信号的