Const init_info As String = "InitInfo"
Const end_row_op As Integer = 100  'tmp
Const end_row_holiday As Integer = 100  'tmp
Const sheet_name_op As String = "Project_YY"  'tmp
Const sheet_name_holiday As String = "Holiday"  'tmp
Const column_index_task As Integer = 3 'tmp
Const column_index_cost As Integer = 5 'tmp
Const column_index_start_date As Integer = 6 'tmp
Const column_index_end_date As Integer = 7 'tmp
Const column_index_man As Integer = 8 'tmp
Const column_index_sort As Integer = 9 'tmp
Const column_index_holiday As Integer = 2 'tmp
Const column_index_workday As Integer = 3 'tmp

Function is_date_in_col(ByVal sheet_name As String, ByVal col As Integer, ByVal value As Date) As Integer
    Dim end_row As Integer
    end_row = end_row_holiday 'tmp  get_row_range
    
    Dim test_row As Integer
    Dim ret As Integer
    is_date_in_col = 0
    
    Dim col_date As Date
    
    For test_row = 3 To end_row
        col_date = Sheets(sheet_name).Cells(test_row, col).value
        If value = col_date Then
            is_date_in_col = test_row
            Exit For
        End If
    Next
End Function

Function is_date_in_holiday_list(ByVal in_date As Date) As Boolean
    
    If is_date_in_col(sheet_name_holiday, column_index_holiday, in_date) <> 0 Then
        is_date_in_holiday_list = True
    Else
        is_date_in_holiday_list = False
    End If
    
End Function

Function is_date_in_workday_list(ByVal in_date As Date) As Boolean
    
    If is_date_in_col(sheet_name_holiday, column_index_workday, in_date) <> 0 Then
        is_date_in_workday_list = True
    Else
        is_date_in_workday_list = False
    End If
    
End Function

Function is_satday_or_sunday(ByVal in_date As Date) As Boolean
    Dim wd As Integer
    wd = Weekday(in_date)
    
    If wd = vbSunday Or wd = vbSaturday Then
        is_satday_or_sunday = True
    Else
        is_satday_or_sunday = False
    End If
    
End Function

Function get_next_workday(ByVal wd As Date) As Date
    wd = wd + 1
    
    While True
    
        If is_date_in_holiday_list(wd) Then
            wd = wd + 1
            
        ElseIf is_date_in_workday_list(wd) Then
            get_next_workday = wd
            Exit Function
        
        ElseIf is_satday_or_sunday(wd) Then
            wd = wd + 1
            
        Else
            get_next_workday = wd
            Exit Function
            
        End If
        
    Wend

End Function

Function calc_end_date(ByVal start_date As Date, ByVal cost_from_begin As Double, ByRef end_date As Date, ByRef cost_used As Double)

    end_date = start_date
    cost_used = cost_from_begin
    
    While cost_from_begin > 1
        cost_from_begin = cost_from_begin - 1
        cost_used = cost_used - 1
        end_date = get_next_workday(end_date)
    Wend

End Function

Function get_next_task(ByRef row_edit As Integer) As Boolean

    get_next_task = False
    
    Dim in_row As Integer
    in_row = row_edit
    
    Dim new_sort As Integer
    new_sort = 0
    
    Dim in_sort As Integer
    in_sort = Sheets(sheet_name_op).Cells(in_row, column_index_sort).value
    
    Dim target_sort As Integer
    Dim tmp_sort As Integer
    target_sort = 32767
    
    For i = 3 To end_row_holiday
        tmp_sort = Sheets(sheet_name_op).Cells(i, column_index_sort).value
        
        If tmp_sort > in_sort Then
            get_next_task = True
            
            If tmp_sort < target_sort Then
                target_sort = tmp_sort
                row_edit = i
            End If
            
        End If
    Next

End Function

Private Sub Worksheet_Change(ByVal Target As Range)

    If Target.Column <> column_index_start_date Then
        Exit Sub
    End If
    
    Dim cost_used As Double
    cost_used = 0

    Dim row_edit As Integer
    row_edit = Target.Row
    
    Dim row_edit_cost As Double
    row_edit_cost = Sheets(sheet_name_op).Cells(row_edit, column_index_cost).value
    
    Dim start_date As Date
    start_date = Sheets(sheet_name_op).Cells(row_edit, column_index_start_date).value
    
    'If start_date = "" Then
    '    MsgBox "have not input start date"
    '    Exit Sub
    'End If
    
    'if start_date is not workday then error

    cost_from_begin = row_edit_cost + cost_used
    
    Dim end_date As Date
    end_date = start_date
    
    calc_end_date start_date, cost_from_begin, end_date, cost_used
    Sheets(sheet_name_op).Cells(row_edit, column_index_end_date).value = end_date
    
    'next edit row
    While get_next_task(row_edit)
        
        start_date = end_date
        If cost_used >= 1 Then
            start_date = get_next_workday(start_date)
            cost_used = cost_used - 1
        End If
        
        Sheets(sheet_name_op).Cells(row_edit, column_index_start_date).value = start_date
        
        calc_end_date start_date, cost_from_begin, end_date, cost_used
        Sheets(sheet_name_op).Cells(row_edit, column_index_end_date).value = end_date
        
    Wend
    
End Sub

schedule.csv

No.,TaskName,,Cost,StartDate,EndDate,Man,Sort
1,TaskX,,3,,,,
2,,SubX1,1,2022/1/26,2022/1/27,Gu,2
3,,SubX2,2,,,Li,
4,TaskY,,5,,,,
5,,SubY1,2,,,Rui,
6,,SubY2,2,2022/1/24,2022/1/25,Gu,1
7,,SubY3,1,,,Rui,
8,TaskZ,,8,,,,
9,,SubZ1,3,,,Li,
10,,SubZ2,2,2022/1/29,2022/1/30,Gu,3
11,,SubZ3,3,,,Rui,

vba_pj_0001_auto_date的更多相关文章

  1. TCP/IP笔记(1)

    TCP/IP 背景和介绍 上世纪 70 年代,随着计算机技术的发展,计算机使用者意识到:要想发挥计算机更大的作用,就要将世界各地的计算机连接起来.但是简单的连接是远远不够的,因为计算机之间无法沟通.因 ...

随机推荐

  1. 【源码】RapidJSON 源码剖析(0):关于 RapidJSON

    RapidJSON 源码剖析(0):关于 RapidJSON 为什么会有<RapidJSON 源码剖析>系列博文? 之前转载的 Technique to Read Source Code ...

  2. Java ”框架 = 注解 + 反射 + 设计模式“ 之 注解详解

    Java "框架 = 注解 + 反射 + 设计模式" 之 注解详解 每博一文案 刹那间我真想令时光停住,好让我回顾自己,回顾失去的年华,缅怀哪个穿一身短小的连衣裙 和瘦窄的短衫的小 ...

  3. Linux(CentOS)安装MinIo,详细教程,附防火墙端口开放操作

    Linux安装MinIo(已配置开机重启) 1,准备安装目录和文件 系统:CentOs #进入安装目录 cd /home/minio #在线下载二进制文件 wget https://dl.min.io ...

  4. 打印出来的数据{ob: observer}、vue 中 [__ob__: Observer]问题

    问题效果: 理想效果: 解决方案:JSON.parse(JSON.stringify( ob )) 首先我们要把这个数据获取原始数据 JSON.stringify([data])   变成字符串 然后 ...

  5. GPS地图生成01之概述

    图片来源: Author: Tang Email: jianbo.tang@csu.edu.cn

  6. ve-plus:基于 vue3.x 桌面端UI组件库|vue3组件库

    VE-Plus 自研轻量级 vue3.js 桌面pc端UI组件库 经过一个多月的筹划及开发,今天给大家带来一款全新的Vue3桌面端UI组件库VEPlus.新增了35+常用的组件,采用vue3 setu ...

  7. InputManager

    inputManger配置参数说明 https://www.cnblogs.com/xiaoyulong/p/10011256.html 配置方法 https://www.cnblogs.com/td ...

  8. classmethod 修饰符

    title: Python classmethod 修饰符 author: 杨晓东 permalink: classmethod date: 2021-10-02 11:27:04 categorie ...

  9. lg7335 [JRKSJ R1] 异或 题解

    本题的标签中含有trie,但是这道题可以不用trie做. 考虑列出本题的dp方程:设\(f_{k,i}\)表示前\(i\)个数选了\(k\)段的答案,\(s_i\)为数组的前缀异或和 当不选择第\(i ...

  10. [版本控制-Git]-git学习总结

    1.如何将本地的文件添加到已经建好的远程分支上: 1.1 本地文件夹内,右键-git bash - 创建新仓 git init 1.2 git remote add origin 远程仓库的githu ...