ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 4858|回复: 9

[已解决] 快速合并多个不规则单元格

[复制链接]

TA的精华主题

TA的得分主题

发表于 2019-7-22 13:33 | 显示全部楼层 |阅读模式
微信截图_20190719085848.png 请教.zip (9.18 KB, 下载次数: 26)

TA的精华主题

TA的得分主题

发表于 2019-7-22 13:54 | 显示全部楼层
本帖最后由 罗达 于 2019-7-22 13:56 编辑

如果有许多数据,只有写代码合并才行 笨办法合并.gif

TA的精华主题

TA的得分主题

发表于 2019-7-22 14:37 | 显示全部楼层
本帖最后由 约定的童话 于 2019-7-22 15:45 编辑

史上最精简合并代码,哈哈....
Sub 合并()
    Dim i, m
    m = [a65536].End(3).Row
    For i = 2 To m
        If Cells(i, 1) <> "" And Cells(i, 1).Offset(1, 0) = "" Then
            Range(Cells(i, 1), Cells(i, 1).Offset(1, 0)).Merge
            i = i - 1
        End If
        If m - i = 1 Then Exit Sub
    Next
End Sub

TA的精华主题

TA的得分主题

发表于 2019-7-22 15:29 | 显示全部楼层
vba代码如下:
Sub hb()
  js = 0
  qs = 30
  For h = 30 To Cells(Rows.Count, 1).End(xlUp).Row
    For hh = qs To 100000
      If Cells(hh, 1).Interior.ColorIndex = 6 Then
        js = js + 1
      Else
        Exit For
      End If
    Next hh
    If js > 0 Then
      Range(Cells(h, 1), Cells(hh - 1, 1)).Merge
      h = hh
    End If
    qs = h + 1
  Next h
End Sub

TA的精华主题

TA的得分主题

发表于 2019-7-22 16:21 | 显示全部楼层
如果只是黄色的单元格合并的话,可以利用筛选黄色单元格,筛选后,选择可见单元格,合并后居中,再取消筛选即可
20190722001.gif

评分

2

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-7-23 10:21 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
约定的童话 发表于 2019-7-22 14:37
史上最精简合并代码,哈哈....
Sub 合并()
    Dim i, m

你好, 我忘记怎么把你的代码直接插入了, 还有我们公司现在只让用wps,用这个软件的话, 怎么直接插入代码呢

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-7-23 10:22 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
liangmutou01 发表于 2019-7-22 15:29
vba代码如下:
Sub hb()
  js = 0

谢谢, 请问怎么插入代码呢?

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-7-23 10:25 | 显示全部楼层
sishuiren 发表于 2019-7-22 16:21
如果只是黄色的单元格合并的话,可以利用筛选黄色单元格,筛选后,选择可见单元格,合并后居中,再取消筛选 ...

很好用, 非常感谢感谢

TA的精华主题

TA的得分主题

发表于 2019-7-23 11:04 | 显示全部楼层
第一步:选择要合并的列,“定位条件-空值”,在其中输入“=&#11014;”,再摁“ctrl+enter”
第二步:在右边插入辅助列,全部填充数字1
第三步:选择合并列和辅助列,“分类汇总”
第四步:在辅助列,“定位条件-常量”,直接“合并单元格”第五步:选择合并列和辅助列,“分类汇总-全部删除”
第六步:“格式刷”,以辅助列为准刷合并列。

适用于绝大多数情况。

其实只要可以选中所有不规则的单元格,直接点“合并单元格”就可以实现合并。

所以楼主的表格只要可以选中所有的黄色单元格即可:

第一步:直接筛选黄色单元格,“定位条件-可见单元格”
第二步:“合并单元格”

因为恰巧楼主的黄色单元格都有灰色单元格进行隔断,如果仅有黄色连续的单元格,还是用最前面的方法有效。

TA的精华主题

TA的得分主题

发表于 2019-11-23 22:05 | 显示全部楼层
约定的童话 发表于 2019-7-22 14:37
史上最精简合并代码,哈哈....
Sub 合并()
    Dim i, m

为什么WPS运行这段代码的时候WPS就卡死了,,这段代码中m = [a65536].End(3).Row这句的[a65536]是第65536行吧,意思是要把A列全部运行一次吗??比如只有第4行到第100行,怎么修改
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-26 16:08 , Processed in 0.035051 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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