ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 【已解决,感谢baofa2】用VBA进行排序:一个sheet中很多个表,每个表单独排序

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-4-28 09:57 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 flb_2001 于 2024-4-28 16:31 编辑

数据样式如下:


品名参与单位数V1V2V3
A2×
A1
A1
A2×
A2×

品名参与单位数V9V6V5V7V8V4
B2×
B2×
B2×
B1
B3×


×
要求:1.品名A和B分别排序。2.排序第一个字段为参与单位数(升序),接下去的排序字段按顺序分别是V1,V2,V3....排序字段取决于实际V的个数。

image.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-4-28 10:13 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
哪位大佬帮帮忙,指点下!!!

TA的精华主题

TA的得分主题

发表于 2024-4-28 10:16 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-4-28 10:24 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-4-28 10:25 | 显示全部楼层
本帖最后由 baofa2 于 2024-4-28 10:37 编辑
  1. Sub test0() '类似案例,若不行则要有附件,改一下加上单位数排序
  2.   Dim ar, br() As Long
  3.   Dim i As Long, j As Long, k As Long, p As Long
  4.   ar = Range("A1").CurrentRegion
  5.   p = UBound(ar)
  6.   For i = UBound(ar) To 1 Step -1
  7.     If ar(i, 1) = "品名" Then
  8.       k = 2
  9.       For j = 3 To UBound(ar, 2)
  10.         If Len(ar(i, j)) Then
  11.           k = k + 1
  12.           ReDim Preserve br(1 To k)
  13.           br(k) = Val(Mid(ar(i, j), 2))
  14.         Else
  15.           Exit For
  16.         End If
  17.       Next
  18.       BubbleSort ar, i + 1, p, 1, k, 2
  19.       QuickSort ar, br, i, p, 3, k
  20.       p = i - 1
  21.     End If
  22.   Next
  23.   Range("L1").Resize(UBound(ar), UBound(ar, 2)) = ar
  24.   Beep
  25. End Sub

  26. Function BubbleSort(ar, t As Long, b As Long, l As Long, r As Long, k As Long)
  27.   Dim i As Long, x As Long, y As Long, swap, Flag As Boolean
  28.   For i = t To b - 1
  29.     Flag = True
  30.     For y = t To b + t - 1 - i
  31.       If ar(y, k) > ar(y + 1, k) Then
  32.         Flag = False
  33.         For x = l To r
  34.           swap = ar(y, x)
  35.           ar(y, x) = ar(y + 1, x)
  36.           ar(y + 1, x) = swap
  37.         Next
  38.       End If
  39.     Next
  40.     If Flag Then Exit For
  41.   Next
  42. End Function

  43. Function QuickSort(ar, br, t As Long, b As Long, l As Long, r As Long)
  44.   Dim i As Long, j As Long, x As Long, y As Long, pivot As Long, swap
  45.   j = l
  46.   x = r
  47.   pivot = br((l + r) \ 2)
  48.   While j <= x
  49.     Do
  50.       If br(j) < pivot Then j = j + 1 Else Exit Do
  51.     Loop While j < r
  52.     Do
  53.       If pivot < br(x) Then x = x - 1 Else Exit Do
  54.     Loop While x > l
  55.     If j < x Then
  56.       swap = br(j): br(j) = br(x): br(x) = swap
  57.       For y = t To b
  58.         swap = ar(y, j): ar(y, j) = ar(y, x): ar(y, x) = swap
  59.       Next
  60.       j = j + 1: x = x - 1
  61.     Else
  62.       If j = x Then j = j + 1: x = x - 1
  63.     End If
  64.   Wend
  65.   If l < x Then QuickSort ar, br, t, b, l, x
  66.   If j < r Then QuickSort ar, br, t, b, j, r
  67. End Function
复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-4-28 11:16 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
这个排序不能用常规排序法,没有附件,不好弄

TA的精华主题

TA的得分主题

发表于 2024-4-28 11:49 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-4-28 13:28 | 显示全部楼层

谢谢大佬,可以跑,但我忘了说明,需要在原位置进行排序,这样格式不用变


image.png


TA的精华主题

TA的得分主题

 楼主| 发表于 2024-4-28 13:29 | 显示全部楼层
ykcbf1100 发表于 2024-4-28 11:16
这个排序不能用常规排序法,没有附件,不好弄

你可以拷贝这个到excel
image.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-4-28 13:30 | 显示全部楼层
3190496160 发表于 2024-4-28 11:49
上传附件应该可以解决,但是,没有附件就没有办法

我提问的那个是表格,直接复制到excel就行
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-18 10:51 , Processed in 0.042075 second(s), 14 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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