ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

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

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-8-5 17:07 | 显示全部楼层 |阅读模式
请教:如何利用公式者VBA,将总课程表拆分成教师课程表和班级课程表

求助:如何用公式或VBA将Sheet1总课程表生成教师课程表和班级课程表.rar

32.07 KB, 下载次数: 37

TA的精华主题

TA的得分主题

发表于 2024-8-5 20:52 | 显示全部楼层
表2的M2单元格的数据有效性中的括号()改为汉字()
2024-8-5表2代码.png
2024-8-5表3代码.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-8-5 21:30 | 显示全部楼层
蓝桥**版主,您好,我用您帮助VBA代码,没有实现呢?,中文()也改了,请帮忙看看是哪里出了问题?
Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Count > 1 Then Exit Sub
If Target = "" Then Exit Sub
If Target.Address <> "$M$2" Then Exit Sub
Dim hs, Arr, i%, jX, bj$, coL%, ii%
Application.ScreenUpdating = False
Range("d4:i4,d6:i7,d9:ii0,d12:i17,d19:i22").ClearContents
bj = Target.Value: coL = 3
hs = Array(4, 6, 7, 9, 10, 12, 13, 14, 15, 16, 17, 19, 20, 21, 22)
Arr = Sheet1.[a4].CurrentRegion
For i = 4 To UBound(Arr)
      If Arr(i, 9) = bj Then
         For j = 10 To UBound(Arr, 2) Step 15
            coL = coL + 1
            For ii = 0 To UBound(hs)
              Cells(hs(ii), coL) = Arr(i, j + ii)
           Next
      Next
   End If
Next
Application.ScreenUpdating = True
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-8-5 21:35 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
工作表2.png

TA的精华主题

TA的得分主题

发表于 2024-8-5 22:35 | 显示全部楼层
本帖最后由 yynrzwh 于 2024-8-5 22:37 编辑

1.楼主是要调整冲突教师还是要生成课程表?
2.冲突的教师怎么调整?同行调?同一天内调?6天内调?

这段时间看了很多个排课的帖子了。

TA的精华主题

TA的得分主题

发表于 2024-8-6 11:30 | 显示全部楼层
Sub 班级课表()
Application.ScreenUpdating = False
Dim ar As Variant
Dim br()
With Sheets("总课表")
    r = .Cells(Rows.Count, 9).End(xlUp).Row
    y = .Cells(1, Columns.Count).End(xlToLeft).Column
    If r < 7 Then MsgBox "总课表为空!": End
    ar = .Range("i4:cu" & r)
End With
rr = Array(1, 3, 4, 6, 7, 9, 10, 11, 12, 13, 14, 16, 17, 18, 19)
With Sheets("班级课表")
   rs = .Cells(Rows.Count, 9).End(xlUp).Row
   If rs > 21 Then .Rows("22:" & rs).Delete
    k = 1
    For i = 4 To UBound(ar)
        Erase br
        ReDim br(1 To 21, 1 To 6)
        y = 0
        If ar(i, 1) <> "" Then
            For j = 2 To UBound(ar, 2) Step 15
                y = y + 1
                m = 0
                For s = j To j + 14
                    If s <= UBound(ar, 2) Then
                        m = m + 1
                        xh = rr(m - 1)
                        br(xh, y) = ar(i, s)
                    End If
                Next s
            Next j
        End If
        If k > 1 Then
            .Rows("1:21").Copy .Cells(k, 1)
        End If
        For s = 0 To UBound(rr)
            x = rr(s) + k + 1
            .Cells(x, 3).Resize(1, 6) = Empty
        Next s
        .Cells(k, 1) = ar(i, 1) & " 班     课     程     表"
        .Cells(k + 2, 3).Resize(UBound(br), UBound(br, 2)) = br
        k = k + 21
    Next i
End With
Application.ScreenUpdating = True
MsgBox "ok!"
End Sub

TA的精华主题

TA的得分主题

发表于 2024-8-6 11:31 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
求助:如何用公式或VBA将Sheet1总课程表生成教师课程表和班级课程表.rar (57.41 KB, 下载次数: 28)

TA的精华主题

TA的得分主题

发表于 2024-8-6 11:32 | 显示全部楼层
目前只写了生成班级课表的代码,供参考
一次性生成所有班级课表,然后批量打印即可

TA的精华主题

TA的得分主题

发表于 2024-8-6 14:21 | 显示全部楼层
你的总课程表是用什么工具排出来的?还是手工排的?

TA的精华主题

TA的得分主题

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

本版积分规则

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

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

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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