下記マクロでMsgBox "空白です。"の部分の
メッセージボックスは現れるものの
空白です。の文字が出ません。
原因が分かりません。
全シートの左から3枚目以降のシートを対象に
A3:CEの中にデータが存在するかしないかを調べたいです。
データが残っていれば
ms = ms & vbLf & Sheets(i).Name & "にデータが残っています。" で表示されますが
データが無い場合は画像の通り、文字が出ません。
Sub 残データの確認()
Dim i As Long, cnt As Long, r As Long
Dim rng As Range
Dim ms As String
For i = 3 To Sheets.Count
Sheets(i).Select
With ActiveSheet
r = .UsedRange.Row + ActiveSheet.UsedRange.Rows.Count - 1
If r - 2 = 0 Then
On Error Resume Next
Else
On Error GoTo 0
Set rng = .Range("A3:CE" & r)
If WorksheetFunction.CountA(rng) = 0 Then
cnt = cnt + 1
Else
ms = ms & vbLf & Sheets(i).Name & "にデータが残っています。"
End If
End If
End With
Next i
If cnt = Sheets.Count - 3 Then
MsgBox "空白です。"
Else
MsgBox ms
End If
End Sub
No.3ベストアンサー
- 回答日時:
No.1さん、No.2さんのご指摘のとおりだと思います。
空シート数を数えるのではなく、残データシートの有無をフラグで判定する方法はいかがでしょう。
Sub 残データの確認()
Dim i As Long, r As Long
Dim rng As Range
Dim ms As String
Dim allEmpty As Boolean ' 3シート目以降全シート空のフラグ
allEmpty = True ' フラグを初期化
For i = 3 To Sheets.Count
With Sheets(i)
r = .UsedRange.Rows(.UsedRange.Rows.Count).Row
If r >= 3 Then
Set rng = .Range("A3:CE" & r)
If WorksheetFunction.CountA(rng) > 0 Then
ms = ms & vbLf & .Name & "にデータが残っています。"
allEmpty = False ' フラグを偽に設定
End If
End If
End With
Next i
If allEmpty Then ' 3シート目以降全シート空の場合
MsgBox "空白です。" ' 空白メッセージを表示
Else
MsgBox ms ' 残データがあるシートのメッセージを表示
End If
End Sub
新たにマクロまで組んでいただき
ありがとうございます。
実装してみたところ、見事に思った通りの結果
且つ、高速処理で満足しております。
No.2
- 回答日時:
3枚目以降で空白なら
cnt = cnt + 1
をするのですから、
ここの判定は -3 ではなく -2 なんじゃないかな。
If cnt = Sheets.Count - 2 Then
MsgBox "空白です。"
Else
No.1
- 回答日時:
こんばんは
なんだか意図して複雑にしているような・・
>データが無い場合は画像の通り、文字が出ません。
データがない場合をよく考えてみればわかるはずですけれど・・
>MsgBox ms
が実行されるので(変数msの内容は空白文字列)、何も表示されないように見えているだけでしょう。
1シートだけデータを残した状態で実行してみれば、「空白です。」が表示されませんか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) A2~I4179列にあるリストを支社名ごとにシートに分けたいです。 各シート名はA列にある支社名とし 3 2023/08/29 16:46
- Visual Basic(VBA) Excel VBA マクロ シート名を変えずにA列にあるセル名の名前でファイルの分割をしたいです 3 2024/02/05 22:10
- Visual Basic(VBA) WORD VBA プログラム修正をお願いします。 2 2024/04/25 23:43
- Visual Basic(VBA) VBA listBoxについて 2 2024/03/26 16:14
- Visual Basic(VBA) VBAコードについて 2 2024/03/10 12:41
- Visual Basic(VBA) VBAに関して 2 2023/11/09 20:57
- Visual Basic(VBA) マクロについて教えてください。 下記のマクロは以前教えて頂いたマクロです。 マクロを実行すると 指定 6 2024/01/17 17:50
- Visual Basic(VBA) VBAが止まります。 1 2022/09/02 14:51
- Visual Basic(VBA) 配列の勉強をしています。使用する変数の意味、検索条件の書き方が難しいです。 2 2022/09/15 14:06
- Visual Basic(VBA) VBAでoutlook365が起動しません。 4 2022/08/25 13:31
このQ&Aを見た人はこんなQ&Aも見ています
-
つい集めてしまうものはなんですか?
人間誰もは1つ「やたらこればかり集めてしまう」というものがあるもの。 あなたにとって、つい集めてしまうものはなんですか?
-
一回も披露したことのない豆知識
あなたの「一回も披露したことのない豆知識」を教えてください。 「そうなんだね」と「確かに披露する場所ないね」で評価します。
-
「これはヤバかったな」という遅刻エピソード
寝坊だったり、不測の事態だったり、いずれにしても遅刻の思い出はいつ思い出しても冷や汗をかいてしまいますよね。
-
この人頭いいなと思ったエピソード
一緒にいたときに「この人頭いいな」と思ったエピソードを教えてください
-
ハマっている「お菓子」を教えて!
この世には、おいしいお菓子がありすぎて……。 次何を食べたらいいか迷っています。 みなさんが今、ハマっている「お菓子」を教えてください!
-
数字入力後他の文字等が表示される方法について
Excel(エクセル)
-
職場の人から聞かれており、こんなことができるか教えて下さい。 vbaとかはできません。。 下記リスト
Excel(エクセル)
-
Excelで数値を時間数に変換する関数について
Excel(エクセル)
-
-
4
再質問です。マクロの修正箇所を教えてください。
Excel(エクセル)
-
5
エクセルで 自動的に◯や数字を表示させることできます? 例えばなんですが 日付 山田 1 ◯ みたい
Excel(エクセル)
-
6
2列に入っているデータを1列で表示する関数について
Excel(エクセル)
-
7
データチェックを行うエクセルマクロをおしえてほしい
Excel(エクセル)
-
8
Excel 対象のセルに入力が無いとセルに入力できないようにしたい
Excel(エクセル)
-
9
【マクロ】顧客番号にて一致させ、情報を表へ上書きする為には
Excel(エクセル)
-
10
自動入力で今月はMONTH(TODAY())で良いのですが、翌月はどのようにすれば良いでしょうか。
Excel(エクセル)
-
11
エクセルの関数について教えてください
Excel(エクセル)
-
12
エクセルの計算
Excel(エクセル)
-
13
Excelに詳しい方! B列が「日」なら「休」と表示されるようにしたいのに何で全部の曜日に「休」と入
Excel(エクセル)
-
14
祝日と土曜、日曜の合計をカウントしたいです。 Excelで祝日シートを作成しております。 別シートの
Excel(エクセル)
-
15
セルの数を求めたい
Excel(エクセル)
-
16
Excelの表示についての質問
Excel(エクセル)
-
17
Excel 1の位の数字で処理を分岐させたい
Excel(エクセル)
-
18
表中の指定した条件の文字列を結合する方法について
Excel(エクセル)
-
19
Excelの数式の効率化について
Excel(エクセル)
-
20
エクセルで数字の組み合わせを列記したい
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「未使用」と「不使用」ってど...
-
高速フーリエ変換でデータ数が...
-
PCの内蔵メモリにデータは残る?
-
XMLデータってなんですか?
-
パレート図等で「N=100」とあ...
-
エクセルで縦に並んだデータを...
-
ネットカフェから、メールでき...
-
データ用HDDの別のPCへの乗せ替え
-
【MSOffice Publisher2010差し...
-
日本通信の当月利用データ量は...
-
QC手法の管理図のついて質問
-
マクロを簡潔にしたい
-
インスタの設定について。 イン...
-
ワードの差し込み印刷のデータ...
-
フーリエ変換のデータの補間に...
-
電子辞書の画面をPCに映すには
-
スマホアプリのトラッキング 個...
-
d’の求め方
-
スマホデータについて 一時期心...
-
プログレッシブとインターレー...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「未使用」と「不使用」ってど...
-
高速フーリエ変換でデータ数が...
-
日本通信の当月利用データ量は...
-
XMLデータってなんですか?
-
ネットカフェから、メールでき...
-
PCの内蔵メモリにデータは残る?
-
パレート図等で「N=100」とあ...
-
データ用HDDの別のPCへの乗せ替え
-
インスタの設定について。 イン...
-
エクセルで縦に並んだデータを...
-
Excel Webクエリ
-
【MSOffice Publisher2010差し...
-
ワードの差し込み印刷のデータ...
-
エクセルのグラフのデータ系列...
-
Excelの“並び替え”で文字コード...
-
フラッシュメモリ SSD、USB、SD...
-
職務質問で聞かれたデータはど...
-
窓関数(方形窓)について
-
表計算: 多次元の表を作りたい
-
差し込み印刷がうまくできません
おすすめ情報