ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 合并单元格降序大排列

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-6-20 00:00 | 显示全部楼层 |阅读模式

合并单元格降序大排列.rar (136.69 KB, 下载次数: 15)
说明
1、原来乱序 是源表,是初始状态,见下图
初始状态表.png

2、目标是要达成“效果表”的排序效果,按总分降序排列,见下图
总分降序图.png


TA的精华主题

TA的得分主题

发表于 2018-6-20 07:42 来自手机 | 显示全部楼层
源表通常哪有合并单元格?源表有合并单元格通常称为:“垃圾表”!

TA的精华主题

TA的得分主题

发表于 2018-6-20 09:59 | 显示全部楼层
本帖最后由 一把小刀闯天下 于 2018-6-20 10:00 编辑

'被吊打之人设计的表格,写起来确实费劲

Option Explicit

Sub test()
  Dim i, j, k, arr, cnt, first, stp, a, b, c, t
  arr = Range("a2:h" & Cells(Rows.Count, "c").End(xlUp).Row + 1)
  arr(UBound(arr, 1), 1) = "flag"
  For i = 1 To UBound(arr, 1) - 1
    For j = i To UBound(arr, 1) - 1
      If IsNumeric(arr(j, 7)) And Len(arr(j, 7)) > 0 Then first = j: cnt = 0: Exit For
    Next
    For j = first To UBound(arr, 1) - 1
      If IsNumeric(arr(j, 7)) And Len(arr(j, 7)) > 0 Then cnt = cnt + 1
      If Len(arr(j + 1, 1)) > 0 And Len(arr(j + 1, 7)) = 0 Then
        stp = (j - first + 1) / cnt
        For a = first To j - stp Step stp
          For b = a + stp To j Step stp
            If arr(a, 7) < arr(b, 7) Then
              For c = 1 To stp
                For k = 1 To UBound(arr, 2)
                  t = arr(a + c - 1, k): arr(a + c - 1, k) = arr(b + c - 1, k): arr(b + c - 1, k) = t
              Next k, c
            End If
        Next b, a
        i = j: Exit For
      End If
  Next j, i
  [a2].Resize(UBound(arr, 1) - 1, UBound(arr, 2)) = arr
End Sub

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-6-24 21:32 | 显示全部楼层
一把小刀闯天下 发表于 2018-6-20 09:59
'被吊打之人设计的表格,写起来确实费劲

Option Explicit

想和你交个朋友了,可以加QQ吗?私信也可

TA的精华主题

TA的得分主题

发表于 2018-6-24 21:38 | 显示全部楼层
teshia 发表于 2018-6-24 21:32
想和你交个朋友了,可以加QQ吗?私信也可

很少用QQ,有问题可以接着贴上来,我正在看足球,等一下给你看看

直播一下:英格兰:巴拿马 6:1,刚进。你这消息发的不是时候啊,哈哈哈。

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-6-24 22:09 | 显示全部楼层
一把小刀闯天下 发表于 2018-6-24 21:38
很少用QQ,有问题可以接着贴上来,我正在看足球,等一下给你看看

直播一下:英格兰:巴拿马 6:1,刚进 ...

呵,不急不急,刚刚也刷到了6:0,再刷变6:1,火力太猛。
现在结束了,那我就说说我的想法了,先请教,实在是打扰
合并单元格全排序2.rar (12.19 KB, 下载次数: 9)

用了你的排序,非常给力,但我发现 实际用的表  更是要吊打, 比我发上去的表还要复杂一点
里面以 物理研究 为例,几个点位,研究说明有五个,有六个,不同
我原来上传的,都是相同的

这就麻烦了。全排序,估计比较困难。

如果只排物理研究,我看你写的代码,估计可行。(实际情况是我没看懂)
有时间麻烦指点指点,谢谢。
上传了新的附件

TA的精华主题

TA的得分主题

发表于 2018-6-24 22:57 | 显示全部楼层
teshia 发表于 2018-6-24 22:09
呵,不急不急,刚刚也刷到了6:0,再刷变6:1,火力太猛。
现在结束了,那我就说说我的想法了,先请教, ...

'不想对“物理研究”工作表做评价,那不是吊打的问题了,无法用常规方法来处理

'当前工作表“物理研究”有效

'正好要开赛了

Option Explicit

Sub test()
  Dim i, j, k, n, t, m
  ReDim arr(1 To Rows.Count, 1 To 3)
  For i = 3 To Cells(Rows.Count, "c").End(xlUp).Row
    For j = i To Cells(Rows.Count, "c").End(xlUp).Row
      If Len(Cells(j + 1, 1)) > 0 Or Len(Cells(j + 1, "c")) = 0 Then
        n = n + 1
        arr(n, 1) = i: arr(n, 2) = j: arr(n, 3) = Cells(i, "g")
        i = j: Exit For
      End If
  Next j, i
  For i = 1 To n - 1
    For j = i + 1 To n
      If arr(i, 3) < arr(j, 3) Then
        For k = 1 To UBound(arr, 2)
          t = arr(i, k): arr(i, k) = arr(j, k): arr(j, k) = t
        Next
      End If
  Next j, i
  [j3].Resize(Rows.Count - 2, 8).Clear
  For i = 1 To n
    Cells(arr(i, 1), "a").Resize(arr(i, 2) - arr(i, 1) + 1, 8).Copy Cells(3 + m, "j")
    m = m + arr(i, 2) - arr(i, 1) + 1
  Next
End Sub

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2018-6-25 09:39 | 显示全部楼层
本帖最后由 ahnyt 于 2018-6-25 11:02 编辑
teshia 发表于 2018-6-24 22:09
呵,不急不急,刚刚也刷到了6:0,再刷变6:1,火力太猛。
现在结束了,那我就说说我的想法了,先请教, ...

试试这个,看字典表要求,有问题加我的QQ

合并单元格全排序.zip

18.64 KB, 下载次数: 9

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2018-6-25 10:37 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-12-27 05:01 , Processed in 0.040662 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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