質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

1回答

5867閲覧

条件付き書式で変更されたセルの色をvbaで取得したい

退会済みユーザー

退会済みユーザー

総合スコア0

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

1クリップ

投稿2020/03/09 07:14

製品マスターへのデータ登録ツールを作っています。

  1. 必要項目(複数)を入力する
  2. 条件付き書式を使って入力項目の不備があったセルには色をつける
  3. 入力が済んだらマスター登録をvbaで行う

このような流れになっているのですが
条件付き書式を利用して入力エラーを警告しつつ
さらにマスター登録のマクロの中でもう一度
エラー項目が残っていないかチェックしたいと考えています。

しかし
条件付き書式のチェックで着色されたセルも
vbaで .interior.colorindex を取得すると
塗りつぶしなしになってしまいます。

条件付き書式で変更されたセルの色をvbaで取得する方法はありますでしょうか?

あるいは
もっと賢い方法がありましたら
(たとえば条件付き書式に引っかかっている限りマスター登録の実行ボタンを押せない等)
教えていただけると幸いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

makox0105

2020/03/09 08:03

全てVBAで処理しない理由はあるのでしょうか?
退会済みユーザー

退会済みユーザー

2020/03/09 09:07

すべてVBAで処理しないのは 本作業に携わる人がマクロを使えないので(私はツールを作るだけ) 小さな変更が合ったときに条件付き書式のほうが望ましい と言われたからなのです。
guest

回答1

0

ベストアンサー

DisplayFormatに表示中の状態が保持されているようです。
背景色であればDisplayFormat.Interior.Colorで取得できます。

VBA

1Debug.Print Range("A1").DisplayFormat.Interior.Color

投稿2020/03/09 08:02

ttyp03

総合スコア17000

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/03/09 09:10

できました! 全く知りませんでした。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問