ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 考试成绩分析求助

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-10-31 09:08 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
每次考完试都要做成绩分析处理。我再论坛里看到了一些作品,但是我才疏学浅,很多地方看不懂,而且每所学校的要求各不相同,我也不懂得如何更改,之前发过一个文件,但是领导看了后觉得麻烦,所以把我之前的版面更改了,没办法 我只能发到这里,请求有时间的大侠帮忙处理三个表格问题。在此先谢过走过路过的朋友啦!附上文件里的要求,主要是三率表里的要求比较复杂。                                                                                                       1、计算本班的平均分、优秀率、及格率 就得到年级的平均分、优秀率、及格率                                                                               
【年级平均分、优秀率、及格率是在本年级所有班级计算后再取平均数,在两个校区中同一个年级各班数据的平均值,而不是分开取平均值】,【也不是直接由年级总分/年级人数、年级优秀人数/年级人数、年级及格人数/年级人数】                                                                               
2、所有涉及到【差值】都是为班级的数据-年级的数据                                                                               
3、排名:所有排名都是依据【差值】进行排名(在各年级中排名,在两个校区同年级所有班级中排名,而不是分开校区排名)       
【注意:1-4年级在两个校区同年级所有班级中排名
        5年级和6年级分奇数班和偶数班,那么排名是在两个校区同年级中的奇数班或者偶数班中排名】                                                               
4、积分:班级数+1-排名        (在各年级中排名)                                                                       
【注意:1-4年级在两个校区同年级所有班级数+1-排名
        5年级和6年级分奇数班和偶数班,那么积分也是在两个校区同年级中所有奇数班班数+1-排名或者所有偶数班班数+1-排名】                                                                               
6、1-5年级语文、数学、英语优秀分都为>=90,及格分都为>=60                                                                               
   6年级语文:奇数班优秀分>=85、偶数班>=80、奇数班和偶数班及格分都为>=60;                                                                               
   6年级数学:奇数班优秀分>=90、偶数班>=80、奇数班和偶数班及格分都为>=60;                                                                               
   6年级英语:奇数班优秀分>=27、偶数班>=24、奇数班和偶数班及格分都为>=18;                                                                               



补充内容 (2020-12-30 18:46):
已完成,感谢大家的帮助!

成绩分析 纵向20101031.rar

279.84 KB, 下载次数: 120

TA的精华主题

TA的得分主题

发表于 2018-10-31 09:52 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
花点钱找代工吧,这么多事儿花时间不少。

TA的精华主题

TA的得分主题

发表于 2018-10-31 11:48 | 显示全部楼层
理解如下:

1、班级的平均分、优秀率、及格率                                                                          
    计算公式为【班级总分/班级人数、班级优秀人数/班级人数、班级及格人数/班级人数】

2、年级的平均分、优秀率、及格率
    【年级平均分、优秀率、及格率是在两个校区中同一个年级各班  班级的平均分、优秀率、及格率的平均值】      
头像被屏蔽

TA的精华主题

TA的得分主题

发表于 2018-10-31 12:19 来自手机 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
提示: 作者被禁止或删除 内容自动屏蔽

TA的精华主题

TA的得分主题

发表于 2018-10-31 12:33 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-10-31 15:01 | 显示全部楼层
本帖最后由 zopey 于 2018-10-31 15:08 编辑

按班级 统计各科成绩

888.JPG

成绩统计分析.zip (260.22 KB, 下载次数: 126)

评分

3

查看全部评分

TA的精华主题

TA的得分主题

发表于 2018-10-31 15:04 | 显示全部楼层
       If rst1("年级") >= 1 And rst1("年级") <= 5 Then
          If rst1("语文") >= 90 Then
             dic("语文优秀" & str1) = dic("语文优秀" & str1) + 1
          ElseIf rst1("语文") >= 60 Then
             dic("语文及格" & str1) = dic("语文及格" & str1) + 1
          End If
         
          If rst1("数学") >= 90 Then
             dic("数学优秀" & str1) = dic("数学优秀" & str1) + 1
          ElseIf rst1("数学") >= 60 Then
             dic("数学及格" & str1) = dic("数学及格" & str1) + 1
          End If
         
          If rst1("英语") >= 90 Then
             dic("英语优秀" & str1) = dic("英语优秀" & str1) + 1
          ElseIf rst1("英语") >= 60 Then
             dic("英语及格" & str1) = dic("英语及格" & str1) + 1
          End If
         
       ElseIf rst1("年级") = 6 Then
          str2 = rst1("班级") Mod 2
          If (rst1("语文") >= 85 And str2 = 1) And (rst1("语文") >= 80 And str2 = 0) Then
             dic("语文优秀" & str1) = dic("语文优秀" & str1) + 1
          ElseIf rst1("语文") >= 60 Then
             dic("语文及格" & str1) = dic("语文及格" & str1) + 1
          End If
         
          If (rst1("数学") >= 90 And str2 = 1) And (rst1("数学") >= 80 And str2 = 0) Then
             dic("数学优秀" & str1) = dic("数学优秀" & str1) + 1
          ElseIf rst1("数学") >= 60 Then
             dic("数学及格" & str1) = dic("数学及格" & str1) + 1
          End If
         
          If (rst1("英语") >= 27 And str2 = 1) And (rst1("英语") >= 24 And str2 = 0) Then
             dic("英语优秀" & str1) = dic("英语优秀" & str1) + 1
          ElseIf rst1("英语") >= 18 Then
             dic("英语及格" & str1) = dic("英语及格" & str1) + 1
          End If
       End If

TA的精华主题

TA的得分主题

发表于 2018-10-31 15:12 | 显示全部楼层
发现 3处逻辑错误, 第2个 and  应该为 or:
If (rst1("语文") >= 85 And str2 = 1) And (rst1("语文") >= 80 And str2 = 0) Then
If (rst1("数学") >= 90 And str2 = 1) And (rst1("数学") >= 80 And str2 = 0) Then
If (rst1("英语") >= 27 And str2 = 1) And (rst1("英语") >= 24 And str2 = 0) Then

6楼 附件 已编辑修改后 重新上传。

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-10-31 15:39 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

这是你设计好的系统吗?

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-10-31 15:40 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
zopey 发表于 2018-10-31 11:48
理解如下:

1、班级的平均分、优秀率、及格率                                                        ...

是的  您理解的事正确的
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-12-23 03:44 , Processed in 0.048598 second(s), 16 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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