百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Excel二维表转换一维表,三种方法一网打尽!

liuian 2025-06-13 14:49 11 浏览

今天高顿网校小编向大家分享二维表格转一维表的三种方法,分别用到函数、数据透视表和VBA代码。三种方法各有利弊,表亲可以自行选择。

如下图,A1:E5是数据源,A7:C22是最终要实现的结果样式:

一起动手试试啦!

函数公式法

A7单元格输入

=OFFSET($A$1,INT((ROW()-7)/4)+1,0)

B7单元格输入

=OFFSET($A$1,0,MOD(ROW()-7,4)+1)

C7单元格输入

=OFFSET($A$1,INT((ROW()-7)/4)+1,MOD(ROW()-7,4)+1)

公式向下复制,完成。

高顿财务培训《EXCEL在财务管理中的高级应用》

OFFSET函数通过调整行、列偏移量,改变起始单元格地址,返回现有结果。

以上均以A1为起始单元格。A列的列偏移量始终为0,行偏移量为1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4的数列,以取整函数INT和ROW函数嵌套生成。

B列的行偏移量始终为0,列偏移量为1,2,3,4,1,2,3,4,1,2,3,4,1,2,3,4的数列,以求余函数MOD和ROW函数嵌套生成。

C列行列偏移量为A、B两列综合。

透视表法

Step1

依次按下Alt、D、P,进入多表透视向导。

选择【多重合并计算数据区域】、创建【数据透视表】

Step2

创建单页字段。

Step3

选择数据源所在区域并添加

Step4

将生成的数据透视表字段设置如下:

5Step5

报表布局调整为【以表格形式显示】、【重复所有项目标签】

6Step6

取消分类汇总行和总计

7Step7

在数据透视表选项中,去掉勾选显示展开/折叠按钮

最终结果如下,可自行调整美化。

VBA代码法

Step1

按Alt+F11键,进入VBE编辑窗口,输入如下代码:

Sub test()

Dim arr, i%, j%, n%

'声明整形变量i,j,n和arr

arr = Range("a1:e5")

'将二维表区域装入数组arr中

n = 1 '给i赋初始值1

For i = 2 To UBound(arr)

'双重循环嵌套,先行后列,循环终值各为二维表行列数

For j = 2 To UBound(arr, 2)

Cells(n, 7) = arr(i, 1)

'将数组arr中i行1列数值(即车间信息)写入G列

Cells(n, 8) = arr(1, j)

'将数组arr中1行j列数值(即部门信息)写入H列

Cells(n, 9) = arr(i, j)

'将数组arr中i行j列数值写入I列

n = n + 1

'每一次循环即对n加1,用以改变待写入单元格行数

Next '结束列循环

Next '结束行循环

End Sub

Step2

按F5运行该段代码,查看结果:

好啦,今天的内容就到这里,希望小伙伴们能有所收获。

▎感谢本文作者扯淡子excel之家。来源“财会学堂”。转载或引用请尊重原创注明来源。

每天学点财会知识,让你的职场up起来!欢迎关注微信号财会学堂(caikuaixuetang)

相关推荐

如何使用 Crontab 在 Linux 中安排 Cron 作业?

在Linux世界中,自动化运维和任务调度是提升效率的核心技能之一。而说到定时任务调度,「Cron」几乎是无人不知的标配工具。你可以用它按分钟、小时、天、周甚至月的粒度去执行脚本、备份、监控、同步...

迅雷发布下载MCP服务:一句话让AI自动找资源并下载

IT之家6月26日消息,迅雷今日发布下载MCP服务,号称“一句话即可让AI自动帮您下载”,该项服务同时支持PC版迅雷和NAS迅雷,现所有用户均可免费使用。目前迅雷MCP支持...

Linux学习大总结(纯干货)-ubuntu的安装与Linux基础操作

一、Linux简介Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工...

连载嵌入式Linux开发教程:初始Ubuntu

2.5创建和配置虚拟机2.5.1创建虚拟机双击桌面的VMwarePlayer启动快捷方式打开VMwarePlayer软件,运行界面如图2.15所示。点击“创建新虚拟机(N)”,可以创建一台虚拟机...

解决ubuntu关机后自动重启的问题(ubuntu 关机没反应)

1.打开/etc/apt/sources.list,把里面的所有源删除,怕有风险的话先backup;2.然后进入软件与更新,重新选择源和serverthenapt-getupdate。注:我也不...

Ubuntu 24.04设置自动登录(ubuntu设置root自动登陆)

在Ubuntu24.04中设置自动登录,可以通过修改GDM(GNOMEDisplayManager)的配置文件来实现。一、修改GDM配置文件1、打开终端:通过快捷键Ctrl+Alt+T打...

docker-compose备份数据库,在crontab定时任务中不生效解决方法

问题:数据库为PostgreSQL。由于数据库是用docker-compose运行,所以直接用docker-compose命令直接备份。测试终端直接运行备份没问题,将命令添加到crontab定时任务...

crontab定时任务执行时间与系统时间不一致解决方法

Ubuntucrontab定时任务执行时间与系统时间不一致(时区差)查看时间>#ll/etc/localtimelrwxrwxrwx1rootroot35Aug508:56...

如何在 Ubuntu 命令行中使用 Wireshark 进行抓包?

Wireshark是一个开源的网络协议分析工具,因其强大的抓包和分析功能而闻名。无论是调试网络问题、监控流量,还是进行安全审计,它都能派上用场。通常,我们会在带有图形界面的系统中,通过Wires...

Ubuntu 操作系统常用命令详解(ubuntu简单的命令)

UbuntuLinux是一款流行的开源操作系统,广泛应用于服务器、开发、学习等场景。命令行是Ubuntu的灵魂,也是高效、稳定管理系统的利器。本文按照各大常用领域,详细总结Ubuntu必学...

Linux系统如何设置开机自动运行脚本?

大家好,我是良许。在工作中,我们经常有个需求,那就是在系统启动之后,自动启动某个脚本或服务。在Windows下,我们有很多方法可以设置开机启动,但在Linux系统下我们需要如何操作呢?Linu...

【案例】Linux(Ubuntu)定时删除3天前文件夹

我公司有个OCR上传图片系统,每天会生成一个类似2025-05-10的文件夹,为了运维方便和硬盘空间的使用,我需要每天去删除之前的旧文件夹,比较麻烦。借助了Deepseek的帮助,将内容分享一下并给自...

解放你的双手,ubuntu定时自动备份MySQL数据库,亲测有效

1、新建一个文件夹存放备份的数据文件,根据个人需要放在合适的位置mkdir/home/cms_mysqlbackup2、创建脚本文件,我放在home文件夹了,命名为autobackup.shcd...

Linux 如何每 5、10、15 或 30 分钟运行一次 Cron 作业?

在Linux系统中,Cron是一个强大的工具,用于自动化重复性任务。通过合理配置Cron,用户可以轻松实现每5分钟、10分钟、15分钟或30分钟运行一次的定时任务。本文将深入探讨如...

运维实战:深度拆解Systemd定时任务原理,90%的人不知道的玩法

运维实战:深度拆解Systemd定时任务原理,90%的人不知道的高效玩法一、Systemd定时任务的核心原理Systemd定时任务是Linux系统中替代传统cron的现代化解决方案,通过...