お世話になっております。
Sub Macro1()
For i = 1 To Cells(Rows.Count, 1).End(xlUp).Row
if Range("D" & i) <> "いちご" Then
Rows(i).Interior.ColorIndex = 6
End If
Next i
End Sub
この度、こちらのプログラムに特定の文字が入っている時にメッセージを表示させたく、
どの様なプログラムの構成になるのかご質問させていただきました。
例えば[スイカ]と入力されている時、「口腔アレルギー症候群の原因となる食品があります」としたいです。
よろしくお願いいたします。
No.4ベストアンサー
- 回答日時:
#3です。
先の回答で複数対象にする場合は、FindNextを使用しますが、
>現在使用しているプログラムの中に、スイカと入力されている場合メッセージを
>表示させるプログラムを追記したいのですが、それは可能なのでしょうか?
ご質問のコードに追加する場合は、下記のような感じです。
Option Explicit
Sub Macro1()
Dim i As Long, flag As Boolean
Dim keyWord As String, AnsComment As String, msg As String
keyWord = "スイカ" 'ここにセルを指定すれば、セルの値から設定できます。
AnsComment = "口腔アレルギー症候群の原因となる食品があります" 'ここにセルを指定すれば、セルの値から設定できます。
flag = True
For i = 1 To Cells(Rows.Count, 4).End(xlUp).Row
If Range("D" & i) <> "いちご" Then Rows(i).Interior.ColorIndex = 6 '行を黄色くしている
If Range("D" & i) = keyWord Then
If flag = True Then msg = AnsComment & vbCrLf & vbCrLf: flag = False
Cells(i, 4).Interior.ColorIndex = 3 '赤にしている
msg = msg & keyWord & "は、" & i & "行目にあります。" & vbCrLf
End If
Next i
msg = msg & vbCrLf & "確認:対象のセル色を赤にしました。"
MsgBox msg
End Sub
元のコードは、いちご以外の行は黄色くなっていますが、一応スイカのセルは赤にしました。
各色については、変更してください。(いちごは無くしてよかったのかな?)
Qchan1962様、回答ありがとうございます。
こちらのプログラムで理想の処理が実現できました。
修正が加えられるよう分かりやすく説明も一緒に記述していただき、本当にありがとうございました。
またこちらでご質問させていただくと思いますが、その際はよろしくお願いいたします。
No.5
- 回答日時:
別に「スイカ」が存在しているかが知りたいだけならループ内で調べる必要はないと思いますけど。
見つかったらその都度メッセージを出す(その他の処理を行う)というなら別ですが。
Sub Macro1()
Dim i As Long
Dim n As Long
n = Cells(Rows.Count, 1).End(xlUp).Row
For i = 1 To n
If Range("D" & i) <> "いちご" Then
Rows(i).Interior.ColorIndex = 6
End If
Next i
If WorksheetFunction.CountIf(Range("D1:D" & n), "スイカ") > 0 Then _
MsgBox "口腔アレルギー症候群の原因となる食品があります"
End Sub
それより気になるのは、
>Rows(i).Interior.ColorIndex = 6
本当に列の端から端まで塗りつぶす必要があるのでしょうか?
例えば表がA~G列を範囲として使用しているのなら、
Intersect(Rows(i), Range("A:G")).Interior.ColorIndex = 6
と、指定した行列が交差する部分だけを塗りつぶすようにするのが良いかと思いますよ。
めぐみん_様、回答ありがとうございます。
めぐみん_様のおっしゃる通り、列の端から端までを塗りつぶす必要はないですね。記載していただいたこちらを使わせていただきます。
またこちらでご質問させていただくと思いますが、その際はよろしくお願いいたします。
No.3
- 回答日時:
こんばんは、横から失礼します。
スイカは沢山ありますか?
一つであれば、こんな書き方も出来ます。
違った探し方ですが、、
Sub sample()
Dim FindRange As Range, AnsObj As Range
Dim KeyWord As String, AnsComment As String
Set FindRange = Range("D1:D" & Cells(Rows.Count, "D").End(xlUp).Row) ’書き方色々ですがDを強調したく、、D列の最終行までの範囲
KeyWord = "スイカ" 'ここにセルを指定すれば、セルの値から設定できます。
AnsComment = "口腔アレルギー症候群の原因となる食品があります" 'ここにセルを指定すれば、セルの値から設定できます。
Set AnsObj = FindRange.Find(KeyWord, LookAt:=xlWhole) ’FindでFindRange内のKeyWordを探します。
If AnsObj Is Nothing Then ’なければ何もしない
Else
Range(Cells(AnsObj.Row, 1), Cells(AnsObj.Row, 4)).Interior.ColorIndex = 6
' Rows(AnsObj.Row).Interior.ColorIndex = 6
MsgBox AnsComment & vbCrLf & vbCrLf & KeyWord & "は" & AnsObj.Row & "行目にあります"
End If
End Sub
めぐみん_さんのアドバイスにあるように
Keyword = "スイカ"やコメント 口腔アレルギー症候群の原因となる食品があります は、
ケースとして 他のメロンとかに対応する場合に表などに入れて置くのが良いと思います。なので一応変数にしました。(改造しやすいように)
セルにリストを作りそのセルの値をKeyWordにして、KeyWordで表からAnsCommentを抽出するとか、、
(必要ないかもしれませんが)
参考まで
Qchan1962様ご回答ありがとうございます。
はい、スイカは複数入力されております。
今のところアレルギー表示としましてスイカと入力されている時
メッセージを表示させたいのですが、質問欄に記載させていただきました
現在使用しているプログラムの中に、スイカと入力されている場合メッセージを
表示させるプログラムを追記したいのですが、それは可能なのでしょうか?
よろしくお願いいたします。
No.2
- 回答日時:
例えば、
Sub Macro1()
dispmsg=false
For i = 1 To Cells(Rows.Count, 1).End(xlUp).Row
if Range("D" & i) <> "いちご" Then
Rows(i).Interior.ColorIndex = 6
dispmsg=true
End If
Next i
if dispmsg=true then
MsgBox "口腔アレルギー症候群の原因となる食品があります"
endif
End Sub
とか?
No.1
- 回答日時:
>例えば[スイカ]と入力されている時、「口腔アレルギー症候群の原因となる食品があります」としたいです。
これが10個位の物ならコードの中に書けるでしょうし、頻繁に内容が変わるとか20や50や100個と言うならその対になる一覧表をシートに準備する方が良いでしょうし、
更に数千~とかならデータベースを用いるのも手ですよね。(データの入力はそれはそれで覚えなきゃでしょうけど)
必要とする情報量によってやり方は違うと思いますよ。
>メッセージを表示させたく、
メッセージボックスで表示させるのか、どこかのセルの値としてなのか。。。はキチンと記載した方が宜しいかと。
セルに入れるなら『どこのセル(列)なのか』とかね。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- Visual Basic(VBA) エクセル VBA メール本文に指定セルに記載されているURLをリンクとして記載する方法 8 2022/08/08 07:50
- Visual Basic(VBA) Excel VBA キーワードから列を取得して、さらに空欄行を非表示にする 3 2022/10/21 22:49
- Visual Basic(VBA) 前回ご教授いただいたコードに覚えたてのループ処理で品名りんごAから順に20回for nextでループ 7 2023/01/13 22:01
- Visual Basic(VBA) 列と行の名前(重複あり)が交差するセルに、データを入力したい 2 2022/06/25 22:42
- Visual Basic(VBA) VBAが止まります。 2 2022/09/02 14:02
- Visual Basic(VBA) 【VBA】特定のワードが入っている行全体を塗りつぶしたい 4 2022/04/20 15:22
- Visual Basic(VBA) VBAにてメール作成した際、一部指定箇所のみ赤文字にしたいです。 下記の内容ですと作成されたメール本 1 2022/04/27 13:31
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Visual Basic(VBA) 【再々投稿】VBAのプログラムで動作しなくて困っています 8 2022/10/14 09:06
このQ&Aを見た人はこんなQ&Aも見ています
-
あなたの「必」の書き順を教えてください
ふだん、どういう書き順で「必」を書いていますか? みなさんの色んな書き順を知りたいです。 画像のA~Eを使って教えてください。
-
「平成」を感じるもの
「昭和レトロ」に続いて「平成レトロ」なる言葉が流行しています。 皆さんはどのようなモノ・コトに「平成」を感じますか?
-
これ何て呼びますか Part2
あなたのお住いの地域で、これ、何て呼びますか?
-
おすすめのモーニング・朝食メニューを教えて!
コメダ珈琲店のモーニング ロイヤルホストのモーニング 牛丼チェーン店の朝食などなど、おいしいモーニング・朝食メニューがたくさんありますよね。
-
ギリギリ行けるお一人様のライン
おひとり様需要が増えているというニュースも耳にしますが、 あなたが「ギリギリ一人でも行ける!」という場所や行為を教えてください
-
EXCELで特定の文字列を入力→エラー表示したい
その他(Microsoft Office)
-
特定の文字がある行以外を削除するマクロ
その他(Microsoft Office)
-
もしセルが#N/A"なら~をする・・・には?"
Excel(エクセル)
-
-
4
【vba】指定範囲の中に任意の文字があるときの条件分岐
Excel(エクセル)
-
5
エクセルVBA ブックを閉じる前に確認メッセージを表示したい
Excel(エクセル)
-
6
指定文字以外のカウント
Visual Basic(VBA)
-
7
EXCEL VBA で指定した範囲に入力があるかどうか?
Visual Basic(VBA)
-
8
指定した文字があった場合、その行を削除するマクロが欲しいです
Excel(エクセル)
-
9
Excel VBA 空白セルがあったらメッセージボックスで知らせたい
Visual Basic(VBA)
-
10
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
11
メッセージボックスのOKボタンをVBAでクリックさせたい
Visual Basic(VBA)
-
12
マクロ 実行ボタンを押さずに常に実行
Excel(エクセル)
-
13
マクロ 特定のセル値のみクリアする
Visual Basic(VBA)
-
14
エクセルVB ポップアップウィンドウを出す方法
Excel(エクセル)
-
15
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
16
メッセージボックスに表示する文字を大きくしたい
Excel(エクセル)
-
17
別ブックをダイアログボックスで指定してそこにあるシートをコピーしたい
Excel(エクセル)
-
18
VBAでファイルを開くときにファイル名でワイルドカードを使用したいです
その他(プログラミング・Web制作)
-
19
VBA 存在しないシートを選択した時にエラーメッセージを表示するには?
Visual Basic(VBA)
-
20
Excel VBA A列が特定の値以外の場合、その行を削除
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ExcelVBAを使って、値...
-
EXCELで変数をペーストしたい
-
i=cells(Rows.Count, 1)とi=cel...
-
【VBA】シート上の複数のチェッ...
-
DataGridViewで列、行、セルの選択
-
【Excel VBA】指定行以降をクリ...
-
Excelで指定した日付から過去の...
-
Excel vbaで特定の文字以外が入...
-
特定のセルが空白だったら、そ...
-
EXCELのVBA-フィルタ抽出後の...
-
”戻り値”が変化したときに、マ...
-
Excelのプルダウンで2列分の情...
-
セル色なしの行一括削除
-
【VBA】指定したセルと同じ値で...
-
任意フォルダから画像をすべて...
-
【EXCEL VBA】Range("A:A").Fi...
-
VBA実行後に元のセルに戻りたい
-
DataGridViewの各セル幅を自由...
-
VBA初心者です。結合セルを保持...
-
Excel VBAで比較して数値があっ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ExcelVBAを使って、値...
-
i=cells(Rows.Count, 1)とi=cel...
-
特定のセルが空白だったら、そ...
-
Excelで指定した日付から過去の...
-
Excelのプルダウンで2列分の情...
-
【Excel VBA】指定行以降をクリ...
-
特定の文字を条件に行挿入とそ...
-
EXCELで変数をペーストしたい
-
エクセルVBAでコピーして順...
-
TODAY()で設定したセルの日付...
-
VBAでセルをクリックする回...
-
セル色なしの行一括削除
-
VBA実行後に元のセルに戻りたい
-
【Excel】指定したセルの名前で...
-
”戻り値”が変化したときに、マ...
-
Excel vbaで特定の文字以外が入...
-
EXCELのVBA-フィルタ抽出後の...
-
指定した条件で行セルを非表示...
-
VBA初心者です。結合セルを保持...
-
ExcelのVBAで数字と文字列をマ...
おすすめ情報
neKo_deux様、ご回答いただきましてありがとうございます。
補足させていただきます。
私の説明不足でした。申し訳ございません。
正しくはDセルに[いちご]意外にも入力されているデータがございまして、
スイカと入力されている時上記のメッセージを表示させたいご質問になります。
よろしくお願いいたします。