範囲内のセルの最初の3文字が別のセルの内容と等しい場合、列を非表示にするコードを記述しようとしています。範囲内のセルがこのように空白の場合に列を非表示にするためのコードがあります;-
Private Sub Worksheet_Change(ByVal Target As Range)
Dim r As Range, cell As Range
On Error GoTo ErrHandler
Set r = Me.Range("C8:R8")
Application.ScreenUpdating = False
Application.EnableEvents = False
For Each cell In r
If cell.Value = "" Then
cell.EntireColumn.Hidden = True
Else
cell.EntireColumn.Hidden = False
End If
Next
ErrHandler:
Application.ScreenUpdating = True
Application.EnableEvents = True
End Sub
そして、セルの最初の3文字を識別するためのコード;-
Dim LResult As String
LResult = Left ("Alphabet",3)
しかし、「アルファベット」ではなく特定のセルを参照して、2つを組み合わせるにはどうすればよいですか?
これを機能させることはできません-何か提案はありますか?
Private Sub Worksheet_Change(ByVal Target As Range)
Dim r As Range, cell As Range
On Error GoTo ErrHandler
Set r = Me.Range("B7:CG7")
Application.ScreenUpdating = False
Application.EnableEvents = False
Row = 1
col = 1
For Each cell In r
If cell.Value = "" And Left(cell.Value, 3) = cell(Row, col).Value Then
cell.EntireColumn.Hidden = True
Else
cell.EntireColumn.Hidden = False
End If
Next
ErrHandler:
Application.ScreenUpdating = True
Application.EnableEvents = True
End Sub
乾杯