ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 较难的成绩统计代码求助

  [复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-8-21 21:21 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 沉潜 于 2012-8-21 21:21 编辑
mjzxlmg 发表于 2012-8-4 10:13
d.count改为m即可。或改为:dic.count

老师您好,这个学科分析系统我又添加了几个功能,还烦请您帮忙指点完善。
1、自动检测导入数据表头并导入数据。(已完善)
2、希望在【成绩源】上添加总分及班排名和级排名。总分根据设置要求计算。(在他人的帮助下基本能实现,但速度较慢,希望在您那希尔算法的计算排名中集成)
3、学科分析时三残儿童(聋哑盲)不计入考核人数。即:考核人数=(总人数 三残儿童)X 考核比例
4、能添加、显示三残儿童信息,能查询打印班级成绩,能查找修改学生成绩。 学科分析.rar (161.25 KB, 下载次数: 55)

TA的精华主题

TA的得分主题

发表于 2012-8-24 00:03 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 mjzxlmg 于 2012-8-24 00:08 编辑
沉潜 发表于 2012-8-21 21:21
老师您好,这个学科分析系统我又添加了几个功能,还烦请您帮忙指点完善。
1、自动检测导入数据表头并导入 ...
三残儿童列的设置有点突兀,放在姓名列后好些,因为后面的列都是数值,写代码较易。
不过即使改过来,也要重写代码,工作量太大
计算总分可参考下面代码

Sub 计算总分()
    Dim d As Object, arr, brr, i&, j&, sum
    Set d = CreateObject("scripting.dictionary")
    brr = Sheets("设置").[d5].CurrentRegion.Value
    Sheets ("成绩源")
        arr = .[a1].CurrentRegion.Value
        ReDim crr(1 To UBound(arr), 1 To 1)
        For j = 3 To UBound(brr, 2)
            If brr(3, j) = "是" Then d(brr(1, j)) = brr(4, j)
        Next
        For i = 2 To UBound(arr)
            sum = Empty
            For j = 7 To UBound(arr, 2)
                If d.exists(arr(1, j)) Then
                    If Len(arr(i, j)) Then
                        sum = sum + arr(i, j) * d(arr(1, j))
                    End If
                    crr(i, 1) = sum
                End If
            Next
        Next
        crr(1, 1) = "总分"
        .[n1].Resize(UBound(arr)).ClearContents
        .[n1].Resize(UBound(arr)).Value = crr
    End With
    Set d = Nothing
End Sub

TA的精华主题

TA的得分主题

发表于 2012-9-19 15:04 | 显示全部楼层
mjzxlmg 发表于 2012-8-24 00:03
三残儿童列的设置有点突兀,放在姓名列后好些,因为后面的列都是数值,写代码较易。
不过即使改过来,也要 ...

老师您好,请帮忙看看这个附件,谢谢

成绩求助.zip

102.32 KB, 下载次数: 25

TA的精华主题

TA的得分主题

发表于 2012-9-19 16:24 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
你的这个可以在代码中直接填入工作表函数即可。

TA的精华主题

TA的得分主题

发表于 2012-9-19 17:40 | 显示全部楼层
嘉—依 发表于 2012-9-19 15:04
老师您好,请帮忙看看这个附件,谢谢

成绩求助 (1).zip (108.74 KB, 下载次数: 43)

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2012-9-20 12:38 | 显示全部楼层
mjzxlmg 发表于 2012-9-19 17:40

老师您好,在实际运用当中,发现一个问题:麻烦您再帮忙看看,谢谢…………

成绩分析9.20.zip

106.41 KB, 下载次数: 32

TA的精华主题

TA的得分主题

发表于 2012-9-20 20:50 | 显示全部楼层
本帖最后由 mjzxlmg 于 2012-9-20 20:52 编辑
嘉—依 发表于 2012-9-20 12:38
老师您好,在实际运用当中,发现一个问题:麻烦您再帮忙看看,谢谢…………

sub 科成绩分析中
这句
If Arr_out(i, KM + 1) <= Round(d(Arr_out(i, 1) & Arr_out(i, 2)) * BL) Then      '红色指每科的排名列
改为
If Arr_out(i, UBound(Arr_out, 2)) <= Round(d(Arr_out(i, 1) & Arr_out(i, 2)) * BL) Then    ' 红色指总分排名列

TA的精华主题

TA的得分主题

发表于 2012-9-21 08:41 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
嘉—依 发表于 2012-9-20 12:38
老师您好,在实际运用当中,发现一个问题:麻烦您再帮忙看看,谢谢…………

成绩分析.rar (94.76 KB, 下载次数: 42)

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2012-9-21 16:00 | 显示全部楼层
嘉—依 发表于 2012-9-20 12:38
老师您好,在实际运用当中,发现一个问题:麻烦您再帮忙看看,谢谢…………

分年级导出统计数据:

测试附件:
成绩分析.rar (69.35 KB, 下载次数: 60)

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2012-10-11 13:55 | 显示全部楼层
本帖最后由 mjzxlmg 于 2012-10-11 22:51 编辑

在原有基础上增加了按学科导出、各删除导出工作表的功能。

测试附件:
成绩分析.rar (91.77 KB, 下载次数: 114)

在userform1代码区,用图所示方法,把Arr_in(i,1)替换成Cstr(Arr_in(i,1))
捕获.PNG

评分

2

查看全部评分

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-5-1 17:44 , Processed in 0.045777 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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