
エクセルのマクロ(VBA)に関して、ご質問いたします。
私のレベルは入門編で、いろんなサイトや本を見て、そのまま利用しているくらいのものです。
次のコードは、他人様のサイトで見つけたものです。
Sub 結合セルを含むロックしていないセルの値の削除()
Dim c As Range
With ActiveSheet
.Unprotect
For Each c In .UsedRange
If Not (c.Locked) Then c.MergeArea.ClearContents
Next
.Protect UserInterfaceOnly:=True
End With
End Sub
この処理を複数シートに行いたいので、次のコードを(これも他人様のサイトからお借りしています)、上のコードの「Dim c As Range」の後に追加しましたが、アクティブシートは処理されましたが、全部のシートとはいきませんでした。
Dim Sh As Object
For Each Sh In Sheets
単純に足しただけでは、だめなのでしょうか。
参考になるかどうかわかりませんが、シートの中には、値を削除しなくてもいいものも含まれています。
シートが全部で40枚弱あるので、全部のシートをチェックして、ロックされていないセル(結合セル含む)に値が入っていたら、値を削除する処理を、マクロ(VBA)で出来たらいいなっと思っております。
教えていただけますでしょうか。
どうぞよろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
こんにちは。
For Each Sh In Sheets
Next
にして、
With ActiveSheet
を
With Sh
に変えればよいわけです。
「シートの中には、値を削除しなくてもいいものも含まれています。」
消されていけないものはロック設定してあると考えてよいなら、以下のようなコードはいかがでしょうか?ただし、ワークシート自体を保護してある必要はないです。セルのプロパティ自体が、ロック設定してあればよいわけですから。
以下のようにすれば、UsedRangeの中を全部、しらみつぶしにアクセスする必要はなくなると思いますね。それと、結合セルは、もともと、Area なのですから、Area を単位とすれば、セルひとつと関係なくなります。ちょっと範囲の選択が変わってくるわけです。
また、元のコードでは、 .Protect UserInterFaceOnly:=True と、意味が分かりませんね。マクロ処理が過ぎ去った後では、マクロのアクセス許可は、あまり役には立たないだろうと思います。
今は、消す対象とする「値」は、定数の文字列と数字になっています。
他の定数(論理値とエラー値)も含めるなら、
.UsedRange.SpecialCells(xlCellTypeConstants, 23).Areas
になります。
--------------------------------------------------------------
Sub ClearValueMacro()
Dim a As Range 'エリア
Dim ws As Variant 'シート
On Error Resume Next
Application.ScreenUpdating = False
For Each ws In ActiveWorkbook.Worksheets
With ws
.Unprotect
For Each a In .UsedRange.SpecialCells(xlCellTypeConstants, _
xlNumbers + xlTextValues).Areas
If a.Locked = False Then
a.ClearContents
End If
Next a
.Protect
End With
Next ws
Application.ScreenUpdating = True
On Error GoTo 0
End Sub
ご回答およびご説明、ありがとうございます。
ご説明文を参考にして、今後の作成に役立てたいと思います。
教えてくださり、ありがとうございました。
No.1
- 回答日時:
検証してないのですが。
Sub 結合セルを含むロックしていないセルの値の削除()
Dim Sh As Worksheet
Dim c As Range
For Each Sh In Worksheets
With Sh
.Unprotect
For Each c In .UsedRange
If Not (c.Locked) Then c.MergeArea.ClearContents
Next
.Protect UserInterfaceOnly:=True
End With
Next
End Sub
こちらで、どうでしょうか?
ご回答、ありがとうございます。
私も今は確認ができないので、大丈夫かどうかわからないのですが、試してみます。
教えてくださり、ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) まとめシートから集計シートへA列のコードが一致したら1行コピーするマクロをネット上で見つけました。こ 1 2022/08/30 14:11
- Visual Basic(VBA) 複数csvを横に追加していくマクロについて 2 2023/04/25 09:19
- Visual Basic(VBA) 【VBAエラー】Nextに対するForがありません 対策について 5 2022/11/21 21:26
- Visual Basic(VBA) 特定の文字を含むシートだけマクロ処理をしたい 1 2023/05/22 01:43
- Visual Basic(VBA) セルの値からファイルを複数作りたい2 3 2022/10/07 15:54
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2022/05/26 17:19
- Visual Basic(VBA) 【VBA】Excelで罫線を引きたい 3 2022/07/14 12:04
- Excel(エクセル) エクセルシート中の全角英数字を半角に変換したい 4 2022/07/07 13:14
- Visual Basic(VBA) 貼り付けた値が消えていく 以下はソースファイルの2番目のシートのB6から最終行を取得 ターゲットファ 2 2023/07/27 12:23
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
特定のセルだけ結果がおかしい...
-
エクセルのdatedif関数を使って...
-
エクセルのVBAで集計をしたい
-
【マクロ】【配列】3つのシー...
-
vba テキストボックスとリフト...
-
エクセル ドロップダウンリスト...
-
【関数】同じ関数なのに、エラ...
-
Office2021のエクセルで米国株...
-
【マクロ】列を折りたたみ非表...
-
9月17日でサービス終了らし...
-
【マクロ】アクティブセルの時...
-
ページが変なふうに切れる
-
【条件付き書式】シートの中で...
-
【マクロ】3行に上から下に並...
-
【マクロ】オートフィルターの...
-
【マクロ】EXCELで読込したCSV...
-
【画像あり】オートフィルター...
-
他のシートの検索
-
エクセルの循環参照、?
-
Excelファイルを開くと私だけVA...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
9月17日でサービス終了らし...
-
エクセル
-
【マクロ】WEBシステムから保存...
-
エクセルの循環参照、?
-
エクセル ドロップダウンリスト...
-
エクセルのdatedif関数を使って...
-
特定のセルだけ結果がおかしい...
-
【マクロ】A列にある、日付(本...
-
【マクロ】EXCELで読込したCSV...
-
【マクロ】アクティブセルの時...
-
【エクセル】期限アラートについて
-
iPhoneのExcelアプリで、別のシ...
-
【関数】同じ関数なのに、エラ...
-
Excelの新しい空白のブックを開...
-
【マクロ】3行に上から下に並...
-
【マクロ】宣言は、何のために...
-
VBA チェックボックスをオーバ...
-
Excelについての質問です 並べ...
-
【マクロ】アクティブセルの2...
-
【関数】不規則な文章から●●-●●...
おすすめ情報