Sub ExpandDates()
    Dim rCell As Range
    Dim i As Long
    Dim vaDates As Variant
    Dim rNext As Range
    'Loop through the cells that contain dates or date ranges
    For Each rCell In Sheet1.Range("B2:B4").Cells
        'If there's a space, hyphen, space in the cell, it's a date range
        If InStr(1, rCell.Value, " - ") > 0 Then
            'Split the cell contents on space, hyphen, space
            vaDates = Split(rCell.Value, " - ")
            'Loop through the days of the range of dates
            For i = CDate(vaDates(0)) To CDate(vaDates(1))
                'Find the next blank cell in column E to record the results
                Set rNext = Sheet1.Cells(Sheet1.Rows.Count, 5).End(xlUp).Offset(1, 0)
                'Write column A to column E
                rNext.Value = rCell.Offset(0, -1).Value
                'Create a new date in column B using the month that the loop is currently processing
                rNext.Offset(0, 1).Value = CDate(i)
            Next i
        'If no hyphen, it's just a date, so create one line in column E
        Else
            Set rNext = Sheet1.Cells(Sheet1.Rows.Count, 5).End(xlUp).Offset(1, 0)
            rNext.Value = rCell.Offset(0, -1).Value
            rNext.Offset(0, 1).Value = rCell.Value
        End If
    Next rCell
End Sub