20171104xlVBA进退比较
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进退比较的更多相关文章
- 20171104xlVBA各人各科进退
Sub 各班个人各科进步幅度() Dim dRank As Object Set dRank = CreateObject("Scripting.Dictionary") Dim ...
- 第三十 访问财富进退自如 —Spring交易管理
6月16日本,明确. "应该留给追穷寇勇,不可沽名学霸王.天若有情天亦老,人间正道是沧桑." 有始有终.有往有还.进退自如乃Spring事务管理之道,也是万物生生不息.和谐共处之道 ...
- 20171104xlVBA制作联合成绩条
Dim dGoal As Object Dim dCls As Object Sub 制作联合成绩条() Dim sht As Worksheet Dim HeadRng As Range Dim H ...
- SQL Server2016升级前几点自检
SQL Server2016已经出来一段时间了,而且最新的SP1包也于2016年11月18日正式发布,各种新的特性推出让我们跃跃欲试.那么对于我们真实的业务环境,特别是生产环境要不要"跟风& ...
- XSS 前端防火墙 —— 整装待发
到目前为止,我们把能用前端脚本防御 XSS 的方案都列举了一遍. 尽管看起来似乎很复杂累赘,不过那些是理论探讨而已,在实际中未必要都实现.我们的目标只是为了预警,能发现问题就行,并非要做到滴水不漏的程 ...
- 分布式系统理论基础 - 一致性、2PC和3PC
引言 狭义的分布式系统指由网络连接的计算机系统,每个节点独立地承担计算或存储任务,节点间通过网络协同工作.广义的分布式系统是一个相对的概念,正如Leslie Lamport所说[1]: What is ...
- 小程序和APP谁将主导未来?
APP和小程序的未来会怎么样?小程序的出现真的会加速APP的灭亡吗?今天这篇文章,是对小程序和App未来发展格局的一些思考,更多的是想提醒各位拥抱小程序的的参与者,我们在决定参与这场狂欢的同时,切勿盲 ...
- #研发解决方案#分布式并行计算调度和管理系统Summoner
郑昀 创建于2015/11/10 最后更新于2015/11/12 关键词:佣金计算.定时任务.数据抽取.数据清洗.数据计算.Java.Redis.MySQL.Zookeeper.azkaban2.oo ...
- 优化MySchool数据库设计总结
数据库的设计 一:什么是数据库设计? 数据库设计就是将数据库中的数据实体以及这些数据实体之间的关系,进行规范和结构化的过程. 二:为什么要实施数据库设计? 1:良好的数据库设计可以有效的解决数据冗 ...
随机推荐
- Ubuntu 使用unzip解压乱码的问题
由于win使用的是GBK编码,在win下打包zip的压缩文件在ubuntu下使用unzip解压会出现乱码的问题. 解决方案: 换软件,不用unzip,使用unar 18.04是默认安装的,如果没有默认 ...
- 使用msi自动安装系统
在实际生活中, 还是要尽量使用 自动化 脚本 等来处理/执行问题, 那样更快更省力省时间 要多使用 网络工具, 网络工具在 管理/ 使用网络的过程 中还是很有用的. 要有这种 "多使用网络工 ...
- c 语言中宏定义和定义全局变量的区别
宏定义和定义全局变量的区别: 1 作用时间不同. 宏定义在编译期间即会使用并替换,而全局变量要到运行时才可以. 2 本质类型不同. 宏定义的只是一段字符,在编译的时候被替换到引用的位置.在运行中是没有 ...
- P4390 [BOI2007]Mokia 摩基亚(cdq分治)
一样是cdq的板子 照着园丁的烦恼就好了 代码 #include <cstdio> #include <cstring> #include <algorithm> ...
- 深度学习 目标检测算法 SSD 论文简介
深度学习 目标检测算法 SSD 论文简介 一.论文简介: ECCV-2016 Paper:https://arxiv.org/pdf/1512.02325v5.pdf Slides:http://w ...
- 如何判断一个单向链表是否为回文链表(Palindrome Linked List)
题目:给定一个单向链表,判断它是不是回文链表(即从前往后读和从后往前读是一样的).原题见下图,还要求了O(n)的时间复杂度O(1)的空间复杂度. 我的思考: 1,一看到这个题目,大脑马上想到的解决方案 ...
- Lintcode9-Fizz Buzz-Easy
Fizz Buzz Given number n. Print number from 1 to n. But: when number is divided by 3, print "fi ...
- java中垃圾回收算法讲解
判断对象是否存活的方法: 一.引用计数算法(Reference Counting) 介绍:给对象添加一个引用计数器,每当一个地方引用它时,数据器加1:当引用失效时,计数器减1:计数器为0的即可被回 ...
- Spring-JDBC依赖
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</a ...
- JS基础---到底什么是闭包?它是如何形成的?
1.闭包 先看一个简单的例子 function a() { var i = 0; function b() { alert(++i); } return b; }var c = a(); c(); 这 ...