エクセルのマクロ(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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
誕生日にもらった意外なもの
みなさんがもらった誕生日プレゼントで面白いものがあったらぜひ教えてください!
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
ロックされていないセル内をクリア
Excel(エクセル)
-
Excel VBAで保護されていないセルのクリアー
Excel(エクセル)
-
VBAで結合したセルがクリアできない
Excel(エクセル)
-
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
首吊りどこ締めるの
-
代替処理済のセクタ数がよく分...
-
彼女のことが好きすぎて彼女の...
-
白血球が多いとどんな心配があ...
-
勃起する時って痛いんですか? ...
-
風俗店へ行く前のご飯
-
精液の落とし方を教えてください
-
2つの数値のうち、数値が小さい...
-
EXCELで条件付き書式で空白セル...
-
イタリアから帰国する際、肉製...
-
小数点以下を繰り上げたものを...
-
検便についてです。 便は取れた...
-
これって喉仏ですか? 私は女性...
-
エクセル指定した範囲からラン...
-
エクセルで数式の答えを数値と...
-
甲状腺が腫れているが血液検査...
-
精子が黄色?
-
知能テストは、今。 義務教育課...
-
一番多く表示のある値(文字列...
-
急いでます!病院から患者様へ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
首吊りどこ締めるの
-
彼女のことが好きすぎて彼女の...
-
白血球が多いとどんな心配があ...
-
勃起する時って痛いんですか? ...
-
検便についてです。 便は取れた...
-
精液の落とし方を教えてください
-
EXCELで条件付き書式で空白セル...
-
イタリアから帰国する際、肉製...
-
精子が黄色?
-
2つの数値のうち、数値が小さい...
-
これって喉仏ですか? 私は女性...
-
エクセル指定した範囲からラン...
-
甲状腺が腫れているが血液検査...
-
風俗店へ行く前のご飯
-
エクセルのラベルの値(文字列...
-
小数点以下を繰り上げたものを...
-
ある範囲のセルから任意の値を...
-
エクセルで数式の答えを数値と...
-
知能テストは、今。 義務教育課...
-
MIN関数で空白セルを無視したい...
おすすめ情報