广告合作
  • 今日头条

    今日头条

  • 百度一下

    百度一下,你就知道

  • 新浪网

    新浪网 - 提供新闻线索,重大新闻爆料

  • 搜狐

    搜狐

  • 豆瓣

    豆瓣

  • 百度贴吧

    百度贴吧——全球领先的中文社区

  • 首页 尚未审核订阅工具 订阅

    Excel中用VBA解决合并单元格无法排序的问题

    来源:网络收集  点击:  时间:2024-07-09
    【导读】:
    当我们在Excel中对合并的单元格排序的时候会提示:此操作要求合并单元格具有相同大小。在这个经验分享之前,也给大家介绍过ExcelVBA宏的使用了,不会的朋友可以去我的分享里查看。那么现在我教大家一个用VBA宏命令解决合并单元格无法排序的方法。工具/原料moreExcelVBA方法/步骤1/7分步阅读

    在日常办公中经常遇到合并单元格无法排序的问题,

    一般,我们会取消合并,取消合并后,会有很多空白单元格,那么又得去挨个填充单元格,填充完成后,重新排序,排序完成后,还得挨个合并相同的单元格,

    这样一来一回,

    数据量小的就还好,如果数据量大的话,工作量就非常巨大了,而且还容易出错。

    下面我们介绍一种用VBA宏处理的方法,灵活使用,效果更好。

    2/7

    现有如下表格,我们要对工程量排序,但直接排序会报错:此操作要求合并单元格具有相同大小。

    3/7

    我们打开 开发工具中的Visual Basic,将下列代码复制到编辑框中:

    Sub 取消合并单元格并填充空白单元格()

    Dim j

    Dim k, l

    k = InputBox(请输入合并单元格所在列)

    l = Cells(Rows.Count, k).End(xlUp).Row

    Columns(k).UnMerge

    l = Cells(Rows.Count, k).End(xlUp).Row

    For j = 1 To l Step 1

    If Cells(j, k) = Then

    Cells(j, k) = Cells(j - 1, k)

    End If

    Next

    End Sub

    Sub 合并单元格()

    Dim i

    Dim k, l

    Application.DisplayAlerts = False

    k = InputBox(请输入合并单元格所在列)

    l = Cells(Rows.Count, k).End(xlUp).Row

    For i = l To 2 Step -1

    If Cells(i, k) = Cells(i - 1, k) Then

    Range(Cells(i - 1, k), Cells(i, k)).Merge

    End If

    Next

    Application.DisplayAlerts = True

    End Sub

    4/7

    打开宏,执行:取消合并单元格并填充空白单元格 命令,

    5/7

    弹出对话框中输入:要整理的单元格列号:D(指工程量列)整理后如下图2

    再次执行宏命令:取消合并单元格并填充空白单元格,输入C(指工程名)

    执行后,如下图3,将合并的单元格都拆分并填充了值。

    这样,就可以排序了。

    6/7

    排序完成后,再执行宏命令:合并单元格 ,并输入需要合并相同值的单元格所在列。C

    再执行宏命令:合并单元格 ,输入 D

    这样合并单元格排序就完成了。

    7/7

    敲了一下午键盘,不知道大家掌握了没有,

    刚开始用会觉得陌生,后面用多了,就会感觉很方便了。

    若觉得有所帮助,希望大家高抬贵手点个赞吧,花了一下午时间整理出来的。谢谢大家。

    注意事项

    本文仅供参考!

    本文关键词:

    版权声明:

    1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

    2、本站仅提供信息发布平台,不承担相关法律责任。

    3、若侵犯您的版权或隐私,请联系本站管理员删除。

    4、文章链接:http://www.1haoku.cn/art_945322.html

    相关资讯

    ©2019-2020 http://www.1haoku.cn/ 国ICP备20009186号05-06 11:57:35  耗时:0.032
    0.0322s