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

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

ただいまの
回答率

89.86%

EXCEL 条件付き書式について

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,236

yuuta0305

score 30

質問です。
Excelの条件付き書式を使うときに

例えば、C列のプルダウンから名前を選択時にB列を指定の色で塗りつぶしたい場合、どのように設定すべきでしょうか?

また、B列で塗りつぶしたところは、あとでその行全てを他の色で塗りつぶしたい場合に、その条件付書式が入ってるところも上書きして塗りつぶす事を可能に設定する事は可能でしょうか?

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 4

+2

C列のプルダウンから名前を選択時にB列を指定の色で塗りつぶしたい場合、どのように設定すべきでしょうか?

C列が空白でないという条件ではどうでしょうか。
=(ISBLANK(C列)=False)

B列で塗りつぶしたところは、あとでその行全てを他の色で塗りつぶしたい場合に、その条件付書式が入ってるところも上書きして塗りつぶす事を可能に設定する事は可能でしょうか?

塗りつぶしても、条件付き書式の方が優先されるので駄目でしょう。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/11 05:09 編集

    回答ありがとうございます。
    前者については出来そうです。

    後者については、恐らく条件付き書式に優先度を設けるなどして複数の条件を設定させるしかなさそうですね…。

    キャンセル

+2

色の判定はマクロでないとできないので、次のような感じにするとよいかと思います。

標準モジュールに以下の関数を追加。

' セルが任意の色で塗りつぶされていればTRUE、デフォルトのままならFALSEを返す
Function IsBackColor(c As Range)
    IsBackColor = c.Interior.ColorIndex <> xlColorIndexNone
End Function

B1の条件付き書式の条件を次のように設定

=AND(ISBLANK(C1)=FALSE,IsBackColor(B1)=FALSE)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/11 18:16

    ![イメージ説明](2fde8f25df5cc30587c01a430808a988.png)

    キャンセル

  • 2018/05/11 18:22

    ExcelではなくGoogleのスプレッドであるなら、タグを修正してください。
    私の職場の環境ではGoogle系のサービスがほとんどガードされていて、これ以上は確認できません。
    ごめんなさい。
    新しくアップしてもらった画像も表示できないのです。
    帰宅して気力があれば見てみますが期待しないでください。

    キャンセル

  • 2018/05/11 18:26

    > ttyp03
    ありがとうございます。
    明確なタグはないので、Googleをいれました。タグの追加希望は出しました。

    キャンセル

checkベストアンサー

0

Googleスプレッドシートで試してみました。
結論から言いますと、できませんでした。
Rangeオブジェクトから色を取得する関数はあるのですが、条件付き書式で色を変えると、その色を取得してしまうので、任意に設定した色と区別がつかないのです。
もしかしたら別々に取得できるのかもしれませんが、今のところ時間がなくそこまで調べ切れておりません。
とりあえず試してみた方法を掲載しておきますので、参考にしてください。

スクリプトエディタに下記の関数を追加

function IsBackColor(c) {
  return (SpreadsheetApp.getActiveSheet().getRange(c).getBackground() != '#ffffff');
}

B1セルの条件付き書式(カスタム数式)

=AND(ISBLANK(C1)=FALSE, IsBackColor("B1")=FALSE)

やっていることはExcel版で回答したやつを、Googleスプレッドシートに移植しただけです。
ひとつ違うのは関数にB1と渡すとセルのオブジェクトではなく、値そのものが渡ってしまうので参照方法を変更しています。
これももしかしたらオブジェクトそのものを渡せるかもしれませんが、久しぶりに触ったので思い出せませんでした。
すみません。
以上、参考まで。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/12 20:40 編集

    色々調べて頂きありがとうございます。

    色々と効率化のために出来ないか質問してみましたが、どうやら一筋縄ではいかないようですね。

    これ以上調べて頂くのは申し訳ないので、ここでクローズとします。ありがとうございました。^ - ^

    キャンセル

0

イメージ説明

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 89.86%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる