ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 根据总课程表分别生成班级课程表和教师课程表

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-8-7 09:19 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
image.png
不同班级是否视为连续?

TA的精华主题

TA的得分主题

发表于 2024-8-7 09:28 | 显示全部楼层
Sub 教师课表()
Application.ScreenUpdating = False
Dim ar As Variant, cr As Variant
Dim br()
With Sheets("总课表")
    r = .Cells(Rows.Count, 9).End(xlUp).Row
    If r < 7 Then MsgBox "总课表为空!": End
    ar = .Range("i4:cu" & r)
End With
With Sheets("教师名单")
    rs = .Cells(Rows.Count, 1).End(xlUp).Row
    If rs < 2 Then MsgBox "教师名单表为空!": End
    cr = .Range("a1:a" & rs)
End With
For j = 3 To UBound(ar, 2)
    If ar(2, j) = "" Then ar(2, j) = ar(2, j - 1)
Next j
rr = Array(1, 3, 4, 6, 7, 9, 10, 11, 12, 13, 14, 16, 17, 18, 19)
With Sheets("教师课表")
    .Activate
   rs = .Cells(Rows.Count, 9).End(xlUp).Row
   If rs > 21 Then .Rows("22:" & rs).Delete
    k = 1
    For s = 2 To UBound(cr)
        Erase br
        ReDim br(1 To 21, 1 To 6)
        y = 0
        If cr(s, 1) <> "" Then
            xm = cr(s, 1)
             For j = 2 To UBound(ar, 2) Step 15
                y = y + 1
                For ss = j To j + 14
                    If ss <= UBound(ar, 2) Then
                        For i = 4 To UBound(ar)
                            zd = ar(i, ss)
                            If InStr(zd, xm) > 0 Then
                                zf = ar(2, ss)
                                kc = Split(ar(i, ss), Chr(10))(0) & Chr(10) & ar(i, 1)
                                If InStr(zf, "早") > 0 Then
                                    br(1, y) = kc
                                ElseIf InStr(zf, "上") > 0 Then
                                    If ar(3, ss) = 1 Or ar(3, ss) = 2 Then
                                        br(ar(3, ss) + 2, y) = kc
                                    Else
                                        br(ar(3, ss) + 3, y) = kc
                                    End If
                                ElseIf InStr(zf, "自") > 0 And InStr(zf, "晚") = 0 Then
                                    br(ar(3, ss) + 8, y) = kc
                                ElseIf InStr(zf, "下") > 0 Then
                                    br(ar(3, ss) + 10, y) = kc
                                ElseIf InStr(zf, "后") > 0 Then
                                    br(ar(3, ss) + 12, y) = kc
                                ElseIf InStr(zf, "晚") > 0 Then
                                    br(ar(3, ss) + 15, y) = kc
                                End If
                            End If
                        Next i
                    End If
                Next ss
            Next j
            If k > 1 Then
                .Rows("1:21").Copy .Cells(k, 1)
            End If
            For ss = 0 To UBound(rr)
                x = rr(ss) + k + 1
                .Cells(x, 3).Resize(1, 6) = Empty
            Next ss
            .Cells(k, 1) = cr(s, 1) & "  教  师   课   程   表"
            .Cells(k + 2, 3).Resize(UBound(br), UBound(br, 2)) = br
            k = k + 21
        End If
    Next s
End With
Application.ScreenUpdating = True
MsgBox "ok!"
End Sub

TA的精华主题

TA的得分主题

发表于 2024-8-7 09:29 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-8-7 09:29 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
增加了生成教师课表功能,结果为认真核对,仅供参考

TA的精华主题

TA的得分主题

发表于 2024-8-13 12:22 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-18 12:46 , Processed in 0.039667 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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