Sub 比对两次成绩()
CreateAdvance "进退比较", "月考2", "期中考", "月考2", "月考3"
End Sub
Sub CreateAdvance(ByVal MainName As String, ByVal ShtName1 As String, ByVal ShtName2 As String _
, ByVal ExamName1 As String, ByVal ExamName2 As String)
Dim Ar, Br
Dim sht As Worksheet
Dim Arr() As Variant
Dim dNo As Object
Dim dRank As Object
Dim dRow As Object
Dim OneKey
Dim Key As String Const START_COL As Long = 4
Set sht = ThisWorkbook.Worksheets(MainName)
Set dNo = CreateObject("Scripting.Dictionary")
Set dRank = CreateObject("Scripting.Dictionary")
Set dRow = CreateObject("Scripting.Dictionary")
'获取成绩数组
Ar = GetArray(ShtName1, 0, "A", "S")
Br = GetArray(ShtName2, 0, "A", "S")
'
For i = LBound(Ar) + 1 To UBound(Ar) Step 1 Key = CStr(Ar(i, 1))
dNo(Key) = Array(Ar(i, 1), Ar(i, 2), Ar(i, 3)) '储存号 名 班 信息
For J = LBound(Ar, 2) To UBound(Ar, 2)
K = Key & ExamName1 & Ar(1, J) '创建关键字 学号 & 考试名称 & 科目/排名
'Debug.Print K
dRank(K) = Ar(i, J) '储存所有信息
Next J
Next i
For i = LBound(Br) + 1 To UBound(Ar) Step 1
Key = CStr(Br(i, 1))
dNo(Key) = Array(Br(i, 1), Br(i, 2), Br(i, 3)) '储存号 名 班 信息
For J = LBound(Br, 2) To UBound(Br, 2)
K = Key & ExamName2 & Br(1, J) '创建关键字 学号 & 考试名称 & 科目/排名
'Debug.Print K
dRank(K) = Br(i, J) '储存所有信息
Next J
Next i '重定义合并成绩表数组 行数为学生人数+标题1行 列数为每科4列 只保留排名列所以/2
ReDim Arr(1 To dNo.Count + 1, 1 To (UBound(Ar, 2) - START_COL + 1) / 2 * 4 + START_COL - 1)
'Debug.Print UBound(Arr, 2)
For J = 1 To START_COL - 1
Arr(1, J) = Ar(1, J)
Next J
'编制新表头
x = 0
For J = START_COL To UBound(Ar, 2)
If Ar(1, J) Like "*排*" Then
x = x + 1
y = (START_COL - 1) + (x - 1) * 4 + 1
Arr(1, y) = ExamName1 & Ar(1, J)
Arr(1, y + 1) = ExamName2 & Ar(1, J)
Arr(1, y + 2) = Ar(1, J) & "进退幅度"
Arr(1, y + 3) = Ar(1, J) & "进退排名"
End If
Next J '将字典中的学生信息赋值给数组
i = 1
For Each OneKey In dNo.Keys
i = i + 1
Ar = dNo(OneKey)
Arr(i, 1) = CStr(Ar(0))
Arr(i, 2) = Ar(1)
Arr(i, 3) = Ar(2)
For J = START_COL To UBound(Arr, 2)
If Arr(1, J) Like "*排" Then
Key = CStr(Arr(i, 1)) & Arr(1, J)
'Debug.Print Key
Arr(i, J) = dRank(Key)
ElseIf Arr(1, J) Like "*幅度" Then
Arr(i, J) = Val(Arr(i, J - 2)) - Val(Arr(i, J - 1))
End If
Next J
Next OneKey '分班分科插入进退步幅的排名公式
With sht
.Cells.Clear
Set Rng = .Cells(1, 1)
Set Rng = Rng.Resize(UBound(Arr), UBound(Arr, 2))
Rng.Value = Arr
Sort_2003 Rng, True, True, 3
Arr = Rng.Value
For i = LBound(Arr) + 1 To UBound(Arr)
Key = CStr(Arr(i, 3))
If Not dRow.Exists(Key) Then
Ar = Array(i, 0)
dRow(Key) = Ar
Else
Ar = dRow(Key)
Ar(1) = i
dRow(Key) = Ar
End If
Next i For J = 1 To UBound(Arr, 2)
If Arr(1, J) Like "*排名" Then
For Each OneKey In dRow.Keys
Ar = dRow(OneKey)
StartRow = Ar(0)
EndRow = Ar(1)
Set OneRng = .Range(.Cells(StartRow, J), .Cells(EndRow, J))
AddRankFormula OneRng, StartRow, EndRow
Next OneKey
End If
Next J '复制粘贴替换公式
Arr = Rng.Value
Rng.Value = Arr
'格式调整
Rng.Columns.AutoFit
SetBorders Rng
SetCenters Rng
End With Set dNo = Nothing
Set dRank = Nothing
Set sht = Nothing
Set Rng = Nothing End Sub
Public Function GetArray(ByVal SheetName As String, ByVal HeadRow As Long, ByVal StartCol As String, ByVal EndCol As String) As Variant
Dim sht As Worksheet
Dim Rng As Range
Dim Arr As Variant
Set sht = ThisWorkbook.Worksheets(SheetName)
With sht
EndRow = .Cells(.Cells.Rows.Count, StartCol).End(xlUp).Row
Set Rng = .Range(.Cells(HeadRow + 1, StartCol), .Cells(EndRow, EndCol))
Arr = Rng.Value
GetArray = Arr
End With
Set Rng = Nothing
Set sht = Nothing
Erase Arr
End Function
Public Sub Sort_2003(ByVal Rng As Range, Optional WithHeader As Boolean = True, Optional OrderByAscending As Boolean = True, Optional SortColumnNo As Long = 1)
With Rng
.Sort _
Key1:=Rng.Cells(1, SortColumnNo), Order1:=IIf(OrderByAscending, xlAscending, xlDescending), _
Header:=IIf(WithHeader, xlYes, xlNo), MatchCase:=False, Orientation:=xlTopToBottom, SortMethod:=xlPinYin
End With
End Sub
Sub AddRankFormula(ByVal Rng As Range, ByVal StartRow As Long, ByVal EndRow As Long)
Rng.FormulaR1C1 = "=RANK(RC[-1],R" & StartRow & "C[-1]:R" & EndRow & "C[-1])"
End Sub
Public Sub SetBorders(ByVal Rng As Range)
With Rng.Borders
.LineStyle = xlContinuous
.ColorIndex = xlAutomatic
.TintAndShade = 0
.Weight = xlThin
End With
End Sub
Public Sub SetCenters(ByVal Rng As Range)
With Rng
.HorizontalAlignment = xlCenter
.VerticalAlignment = xlCenter
End With
End Sub

  

20171104xlVBA进退比较的更多相关文章

  1. 20171104xlVBA各人各科进退

    Sub 各班个人各科进步幅度() Dim dRank As Object Set dRank = CreateObject("Scripting.Dictionary") Dim ...

  2. 第三十 访问财富进退自如 —Spring交易管理

    6月16日本,明确. "应该留给追穷寇勇,不可沽名学霸王.天若有情天亦老,人间正道是沧桑." 有始有终.有往有还.进退自如乃Spring事务管理之道,也是万物生生不息.和谐共处之道 ...

  3. 20171104xlVBA制作联合成绩条

    Dim dGoal As Object Dim dCls As Object Sub 制作联合成绩条() Dim sht As Worksheet Dim HeadRng As Range Dim H ...

  4. SQL Server2016升级前几点自检

    SQL Server2016已经出来一段时间了,而且最新的SP1包也于2016年11月18日正式发布,各种新的特性推出让我们跃跃欲试.那么对于我们真实的业务环境,特别是生产环境要不要"跟风& ...

  5. XSS 前端防火墙 —— 整装待发

    到目前为止,我们把能用前端脚本防御 XSS 的方案都列举了一遍. 尽管看起来似乎很复杂累赘,不过那些是理论探讨而已,在实际中未必要都实现.我们的目标只是为了预警,能发现问题就行,并非要做到滴水不漏的程 ...

  6. 分布式系统理论基础 - 一致性、2PC和3PC

    引言 狭义的分布式系统指由网络连接的计算机系统,每个节点独立地承担计算或存储任务,节点间通过网络协同工作.广义的分布式系统是一个相对的概念,正如Leslie Lamport所说[1]: What is ...

  7. 小程序和APP谁将主导未来?

    APP和小程序的未来会怎么样?小程序的出现真的会加速APP的灭亡吗?今天这篇文章,是对小程序和App未来发展格局的一些思考,更多的是想提醒各位拥抱小程序的的参与者,我们在决定参与这场狂欢的同时,切勿盲 ...

  8. #研发解决方案#分布式并行计算调度和管理系统Summoner

    郑昀 创建于2015/11/10 最后更新于2015/11/12 关键词:佣金计算.定时任务.数据抽取.数据清洗.数据计算.Java.Redis.MySQL.Zookeeper.azkaban2.oo ...

  9. 优化MySchool数据库设计总结

    数据库的设计   一:什么是数据库设计? 数据库设计就是将数据库中的数据实体以及这些数据实体之间的关系,进行规范和结构化的过程. 二:为什么要实施数据库设计? 1:良好的数据库设计可以有效的解决数据冗 ...

随机推荐

  1. topcoder srm 684 div1

    problem1 link 首先由$P$中任意两元素的绝对值得到集合$Q$.然后枚举$Q$中的每个元素作为集合$D$中的最大值$Max$,这样就能确定最后集合$D$中的最小值要大于等于$Min=\fr ...

  2. Matplotlib 知识点整理

    本文作为学习过程中对matplotlib一些常用知识点的整理,方便查找. 强烈推荐ipython 无论你工作在什么项目上,IPython都是值得推荐的.利用ipython --pylab,可以进入Py ...

  3. OpenCV学习一《Linux下安装OpenCV》

    第一步:安装源码前先安装好需要的第三⽅方环境 需要的编译环境■ [compiler] sudo apt-get install build-essential #  注释说明 64位ubuntu在安装 ...

  4. vscode已有64位版本。

    我的操作系统是win10 Family版本. vscode不知道什么鬼,只要开启没动任何操作,cpu就占到30%. 于是我打开任务管理器,选中vscode进程->转到详细信息->结束cpu ...

  5. [转]Eclipse下开发Struts奇怪异常:org.apache.struts.taglib.bean.CookieTei

    今天早上开始在Eclipse下学习struts,于是按照李兴华老师的<struts入门视频教程>一步一步地充满快乐的学习,等把登陆程序写完,打开浏览器准备运行的时候,奇怪的异常产生了,异常 ...

  6. 报名 | 蚂蚁金服ATEC科技大会 · 上海:数字金融新原力

    小蚂蚁说: 2019年1月4日,蚂蚁金服ATEC城市峰会将以“数字金融新原力(The New Force of Digital Finance)”为主题,在中国上海举办.蚂蚁金服ATEC(Ant Te ...

  7. 【BZOJ】3209: 花神的数论题

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3209 显然是按照二进制位进行DP. 考虑预处理$F[i][j]$表示到了二进制的第$i$位 ...

  8. spoj IITWPC4F - Gopu and the Grid Problem 线段树

    IITWPC4F - Gopu and the Grid Problem no tags  Gopu is interested in the integer co-ordinates of the ...

  9. 阿里云CentOS Linux服务器上搭建邮件服务器遇到的问题

    参考文章: 阿里云CentOS Linux服务器上用postfix搭建邮件服务器 Linux系统下邮件服务器的搭建(Postfix+Dovecot) 本来想自己搭建邮件服务器,但是看到一篇资料表示阿里 ...

  10. 传的参数是url地址时需要特殊处理

    <a href="javascript:;" data-url="{$vo.url}" class="info_generate_qr" ...