ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 如何根据成绩自动生成成绩分析报表

[复制链接]

TA的精华主题

TA的得分主题

发表于 2021-9-26 08:48 | 显示全部楼层 |阅读模式
要求
1. 一段(15%)计10分,二段(20%)计8分、三段(25%)计5分、四段(30%)计3分、五段(10%)计1分,如五段中各段最后一名出现并列情况,均计入该段。
2. 成绩录入后,根据《各段点一览表》模板生成数据并填写在表里.
3. 多个单元成绩分析就生成多个电子表模板,并自动生成报表。
4. 总积分=E+F+G+H+I
5. 生均积分=总积分/参评人数
6. 名次是根据同学科生均积分从高到低排名次

成绩统计册(电子版).rar

31.1 KB, 下载次数: 12

TA的精华主题

TA的得分主题

发表于 2021-9-26 09:04 | 显示全部楼层
一段、二段的成绩怎么划分?

TA的精华主题

TA的得分主题

发表于 2021-9-26 10:18 | 显示全部楼层
猜测应该是按百分比划分分数段,然后按分数段内人数乘以得分计分的。

TA的精华主题

TA的得分主题

发表于 2021-9-26 10:49 | 显示全部楼层
  1. Sub test()
  2.   Dim r%, i%
  3.   Dim arr, brr
  4.   Dim d As Object
  5.   Set d = CreateObject("scripting.dictionary")
  6.   mcd = [{0.15,0.35,0.5,0.8,1;10,8,5,3,1}]
  7.   With Worksheets("学生成绩统计册")
  8.     .AutoFilterMode = False
  9.     r = .Cells(.Rows.Count, 1).End(xlUp).Row
  10.     c = .Cells(3, .Columns.Count).End(xlToLeft).Column
  11.     arr = .Range("a2").Resize(r - 1, c)
  12.   End With
  13.   s = 0
  14.   For j = 5 To UBound(arr, 2) Step 2
  15.     Set d(arr(1, j)) = CreateObject("scripting.dictionary")
  16.     ReDim fsd(1 To UBound(mcd, 2))
  17.     For i = 1 To UBound(mcd, 2)
  18.       fsd(i) = Application.Large(Application.Index(arr, 0, j), (UBound(arr) - 2) * mcd(1, i))
  19.     Next
  20.     For i = 3 To UBound(arr)
  21.       If Not d(arr(1, j)).exists(arr(i, 1)) Then
  22.         ReDim brr(1 To 12)
  23.         brr(1) = arr(1, j)
  24.         brr(2) = arr(i, 1)
  25.         s = s + 1
  26.       Else
  27.         brr = d(arr(1, j))(arr(i, 1))
  28.       End If
  29.       brr(4) = brr(4) + 1
  30.       n = Application.Match(arr(i, j), fsd, -1)
  31.       If Not IsError(n) Then
  32.         brr(n + 4) = brr(n + 4) + 1
  33.       End If
  34.       d(arr(1, j))(arr(i, 1)) = brr
  35.     Next
  36.   Next
  37.   ReDim crr(1 To s, 1 To 12)
  38.   m = 0
  39.   For Each aa In d.keys
  40.     For Each bb In d(aa).keys
  41.       brr = d(aa)(bb)
  42.       For j = 1 To UBound(mcd, 2)
  43.         If Len(brr(j + 4)) <> 0 Then
  44.           brr(j + 4) = brr(j + 4) * mcd(2, j)
  45.           brr(10) = brr(10) + brr(j + 4)
  46.         End If
  47.       Next
  48.       If Len(brr(4)) <> 0 And brr(4) <> 0 Then
  49.         brr(11) = Round(brr(10) / brr(4), 2)
  50.       End If
  51.       m = m + 1
  52.       For j = 1 To UBound(brr)
  53.         crr(m, j) = brr(j)
  54.       Next
  55.     Next
  56.   Next
  57.   With Worksheets("各段点一览表")
  58.     .UsedRange.Offset(4, 0).Clear
  59.     With .Range("a5").Resize(UBound(crr), UBound(crr, 2))
  60.       .Value = crr
  61.       .Borders.LineStyle = xlContinuous
  62.     End With
  63.     With .UsedRange
  64.       .HorizontalAlignment = xlCenter
  65.       .VerticalAlignment = xlCenter
  66.     End With
  67.   End With
  68. End Sub
复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2021-9-26 10:50 | 显示全部楼层
猜测着写的,结果不一定正确。

成绩统计册(电子版).rar

43.28 KB, 下载次数: 23

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-9-28 21:07 | 显示全部楼层

非常感谢你的帮助。
现在只是五分段的意思我没表达清楚。
五分段中15%,35%,60%,90%,100%是指
先将成绩进行排名,再按总人数的前15%记10分,依次再按总人数的前35%记8分,按这样记分下去。
我试了一下,统计结果有出入

TA的精华主题

TA的得分主题

发表于 2021-9-28 21:10 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
cqfdrslyh 发表于 2021-9-28 21:07
非常感谢你的帮助。
现在只是五分段的意思我没表达清楚。
五分段中15%,35%,60%,90%,100%是指

没看明白你的规则,代码仅供参考。

TA的精华主题

TA的得分主题

发表于 2021-9-28 21:16 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
没有看明白!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-4-27 08:33 , Processed in 0.037205 second(s), 17 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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