Search code examples
excelvbaoffset

automate activecell values and offset function


'Please help me to automate the below code using input function, so that i can just type the number in the input box to get desired rows to be filled automatically.'

sub DAY()
GENERAL Macro


ActiveCell.Value = "DAY"

Select Case ActiveCell.Value

Case "DAY"
    ActiveCell.Resize(, 1).Value = "DAY"
    ActiveCell.Offset(, 1).Value = "OFF"
    ActiveCell.Offset(, 2).Value = "DAY"
    ActiveCell.Offset(, 3).Value = "OFF"
    ActiveCell.Offset(, 4).Value = "DAY"
    ActiveCell.Offset(, 5).Value = "OFF"
    ActiveCell.Offset(, 6).Value = "DAY"
    ActiveCell.Offset(, 7).Value = "OFF"
    ActiveCell.Offset(, 8).Value = "DAY"
    ActiveCell.Offset(, 9).Value = "OFF"
    ActiveCell.Offset(, 10).Value = "DAY"
    ActiveCell.Offset(, 11).Value = "OFF"
    ActiveCell.Offset(, 12).Value = "DAY"
    ActiveCell.Offset(, 13).Value = "OFF"


 End Select

 End Sub

'Please help me to automate the below code using input function, so that i can just type the number in the input box to get desired rows to be filled automatically.'


Solution

  • you may use formulas

    Sub Day()
        Dim n As Long
        n = CLng(InputBox("How many days?"))
        With ActiveCell.Resize(1, 2 * n)
            .FormulaR1C1 = "=IF(RC[-1]=""DAY"",""OFF"",""DAY"")"
            .Value = .Value
        End With
    End Sub