重複するオブジェクト名・プロパティ名などを省略できるWithステートメントの使い方です。
Withステートメントの使い方
data:image/s3,"s3://crabby-images/27614/2761454f3ef1a64f4f4bdf84824e4183e3b9c755" alt="with1"
アクティブセルの値を、ひとつ右のセルにコピーするというプログラムで考えてみます。
コピー方法はこの記事のものを使います。
data:image/s3,"s3://crabby-images/e2d06/e2d06c15d4a33e963a46bbb5e483d6ae88304920" alt="with2"
ActiveCell.Next = ActiveCell.Valueというコードを実行すると、コピーが実行されることが確認できます。
data:image/s3,"s3://crabby-images/06019/06019fd1416659a63a85c47b4d50ba9e047cae8b" alt=""
コード内には二回ActiveCellが登場していますが、
data:image/s3,"s3://crabby-images/87aec/87aec1aeae959267766a0c5b5da2e7a23cd117f1" alt="with5"
この状態からコードの前にWith ActiveCellを付け、
data:image/s3,"s3://crabby-images/99082/9908271daa12d8a1de70ab4005c52427099183d1" alt="with6"
コードの後にはEnd Withを付けます。WithとWithでコードを挟んだ状態です。
data:image/s3,"s3://crabby-images/a417a/a417acad2ae7e5b9d008b0a3b0832ebac9653b06" alt="with7"
このWith間では、最初に指定したWithの後ろのActiveCellが省略可能になります。
つまり、以下のコードでActiveCell.Next = ActiveCell.Valueと同じ意味になります。
つまり、以下のコードでActiveCell.Next = ActiveCell.Valueと同じ意味になります。
' vba
' 省略する文字を宣言
With ActiveCell
' .から始めると、ActiveCellが頭に付いたことになる
.Next = .Value
End With
data:image/s3,"s3://crabby-images/52f14/52f148590def95e43eac0f26844c25a8079d9b9b" alt="with8"
なおWithを使う時は、囲んだコードはTabを押して一段下げておくと見やすいコードになります。
data:image/s3,"s3://crabby-images/70271/70271ff3eb0b7e805a331e049dad9b463472eb93" alt=""
Excel(エクセル):重複、一意
重複データ、重複していない(一意の)データ関連の操作、設定まとめです。
重複・一意
条件付き書式やCountIf関数を使用し、重複(一意)のデータだけを強調・洗い出しする方法です。
データの入力規則でCount...
コメント