Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 5691|回复: 7

[已解决]向下合并空单元格 最好用数组

[复制链接]
发表于 2014-8-21 19:47 | 显示全部楼层 |阅读模式
本帖最后由 张雄友 于 2014-8-21 21:28 编辑

向下合并空单元格.
最佳答案
2014-8-21 21:19
张雄友 发表于 2014-8-21 20:49
这样的话,如果选择区域是整列的话,最后的空单元也会合并了。可以防止????

这个不能两全,你要默认到最后一个非空单元格结束也是很容易做的。
  1. Sub 人性化选择问题()
  2.    On Error Resume Next
  3.    Dim arr, st&, en&, rng As Range, n&, m%, i&, j%
  4.    Set rng = Application.InputBox("请选择源区域", "温馨提示", , , , , , 8)
  5.    If rng Is Nothing Then Exit Sub
  6.    n = rng.Row - 1: m = rng.Column - 1
  7.    rng.UnMerge
  8.    arr = rng.Value
  9.    For j = 1 To UBound(arr, 2)
  10.         For i = 1 To UBound(arr)
  11.             If Len(arr(i, j)) Then
  12.               st = i - 1
  13.               If en Then Range(Cells(en + n, j + m), Cells(st + n, j + m)).Merge
  14.               en = i
  15.             End If
  16.         Next
  17.         st = 0: en = 0
  18.     Next
  19. End Sub
复制代码

向下合并空单元格.rar

6.04 KB, 下载次数: 24

发表于 2014-8-21 20:09 | 显示全部楼层
本帖最后由 易安1 于 2014-8-21 20:13 编辑

XXXXX.gif
回复

使用道具 举报

发表于 2014-8-21 20:12 | 显示全部楼层
  1. Sub t()
  2.   Dim arr, st&, en&, rng As Range
  3.   Set rng = Range("A1:A" & Cells(Rows.Count, 1).End(xlUp).Row)
  4.   rng.UnMerge
  5.   arr = rng.Value
  6.   For i = 1 To UBound(arr)
  7.       If Len(arr(i, 1)) Then
  8.         st = i - 1
  9.         If en Then Range(Cells(en, 1), Cells(st, 1)).Merge
  10.         en = i
  11.       End If
  12.   Next
  13. End Sub
复制代码
回复

使用道具 举报

 楼主| 发表于 2014-8-21 20:21 | 显示全部楼层
xdragon 发表于 2014-8-21 20:12

您帮我看看,红字代码哪里用得对不对? 要不要改成其它?

Sub 人性化选择问题()
  On Error Resume Next
  Dim arr, st&, en&, rng As Range
  Set rng = Application.InputBox("请选择源区域", "温馨提示", , , , , , 8)
  If rng Is Nothing Then Exit Sub
  rng.UnMerge
  arr = rng.Value
  For i = 1 To UBound(arr)
      If Len(arr(i, 1)) Then
        st = i - 1
        If en Then Range(Cells(en, rng.Column), Cells(st, rng.Column)).Merge
        en = i
      End If
  Next
End Sub

回复

使用道具 举报

 楼主| 发表于 2014-8-21 20:29 | 显示全部楼层
xdragon 发表于 2014-8-21 20:12

是否支持多列的?还是只支持单列的?
回复

使用道具 举报

发表于 2014-8-21 20:37 | 显示全部楼层
本帖最后由 xdragon 于 2014-8-21 20:42 编辑
张雄友 发表于 2014-8-21 20:21
您帮我看看,红字代码哪里用得对不对? 要不要改成其它?

Sub 人性化选择问题()


你要选择区域的画,代码就没这么容易了。需要考虑不是第一行开始,还有选择的最后一个单元格有空白单元格的情况。

  1. Sub 人性化选择问题()
  2.    On Error Resume Next
  3.    Dim arr, st&, en&, rng As Range, n&, m%, i&, j%
  4.    Set rng = Application.InputBox("请选择源区域", "温馨提示", , , , , , 8)
  5.    If rng Is Nothing Then Exit Sub
  6.    n = rng.Row - 1: m = rng.Column - 1
  7.    rng.UnMerge
  8.    arr = rng.Value
  9.    For j = 1 To UBound(arr, 2)
  10.         For i = 1 To UBound(arr)
  11.             If Len(arr(i, j)) Then
  12.               st = i - 1
  13.               If en Then Range(Cells(en + n, j + m), Cells(st + n, j + m)).Merge
  14.               en = i
  15.             End If
  16.         Next
  17.         If st < en Then Range(Cells(en + n, j + m), Cells(UBound(arr) + n, j + m)).Merge
  18.         st = 0: en = 0
  19.     Next
  20. End Sub
复制代码
支持多行多列。。。
回复

使用道具 举报

 楼主| 发表于 2014-8-21 20:49 | 显示全部楼层
本帖最后由 张雄友 于 2014-8-21 20:50 编辑
xdragon 发表于 2014-8-21 20:37
你要选择区域的画,代码就没这么容易了。需要考虑不是第一行开始,还有选择的最后一个单元格有空白单元 ...

这样的话,如果选择区域是整列的话,最后的空单元也会合并了。可以防止????
回复

使用道具 举报

发表于 2014-8-21 21:19 | 显示全部楼层    本楼为最佳答案   
张雄友 发表于 2014-8-21 20:49
这样的话,如果选择区域是整列的话,最后的空单元也会合并了。可以防止????

这个不能两全,你要默认到最后一个非空单元格结束也是很容易做的。
  1. Sub 人性化选择问题()
  2.    On Error Resume Next
  3.    Dim arr, st&, en&, rng As Range, n&, m%, i&, j%
  4.    Set rng = Application.InputBox("请选择源区域", "温馨提示", , , , , , 8)
  5.    If rng Is Nothing Then Exit Sub
  6.    n = rng.Row - 1: m = rng.Column - 1
  7.    rng.UnMerge
  8.    arr = rng.Value
  9.    For j = 1 To UBound(arr, 2)
  10.         For i = 1 To UBound(arr)
  11.             If Len(arr(i, j)) Then
  12.               st = i - 1
  13.               If en Then Range(Cells(en + n, j + m), Cells(st + n, j + m)).Merge
  14.               en = i
  15.             End If
  16.         Next
  17.         st = 0: en = 0
  18.     Next
  19. End Sub
复制代码
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-5-12 23:04 , Processed in 0.322301 second(s), 12 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表