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

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

ただいまの
回答率

90.52%

  • VBA

    1794questions

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

  • Excel

    1533questions

    Excelは、マイクロソフト社が開発しているデータ集計や分析を行う表計算ソフトの一つです。文書作成や表計算、資料作成などの多彩な機能を備えており、統合パッケージであるMicrosoft Officeに含まれています。

  • Google

    597questions

    Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

  • Google Cloud Platform

    145questions

EXCEL 条件付き書式について

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 292

yuuta0305

score 24

質問です。
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 編集

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

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

    キャンセル

+1

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

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

' セルが任意の色で塗りつぶされていれば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 11:02

    ANDの前の(が抜けてます。

    キャンセル

  • 2018/05/11 11:04

    ん?なくて大丈夫ですよ?

    キャンセル

  • 2018/05/11 11:05

    あ、失礼しました。

    キャンセル

  • 2018/05/11 15:15

    詳細についてありがとうございます。

    こちらエクセルのスプレッドシートでの適応は可能でしょうか?

    キャンセル

  • 2018/05/11 15:17

    「エクセルのスプレッドシート」が何を指しているのかわかりませんが、Excelで実装可能です。
    できないですか?

    キャンセル

  • 2018/05/11 15:38

    オンラインでのクラウド上でのExcelです。

    キャンセル

  • 2018/05/11 16:00

    上記VBAですが、ステートメントの前に ; がありません。(行 2、ファイル「コード」)
    と表示されてしまいます。

    キャンセル

  • 2018/05/11 16:01

    オンラインのExcelは想定していません。
    少し調べてみます。

    キャンセル

  • 2018/05/11 16:04

    ご親切にありがとうございます。

    キャンセル

  • 2018/05/11 16:07 編集

    ツールから、<> スクリプトエディタでしょうか?

    キャンセル

  • 2018/05/11 16:08

    報告いただいたエラーは出ませんでした。
    そもそもExcelOnlineは、マクロを含むブックを開くことはできますが、実行はできないとのことです。
    また条件付き書式も数式で条件を指定することができませんでした。
    実行できる環境があるのでしょうか。
    もう少し調べてみます。

    キャンセル

  • 2018/05/11 16:13

    条件付き書式は、ツール > 条件付き書式 > セルの書式設定の条件
    のところで、カスタム数式がそれに当たるようです。

    キャンセル

  • 2018/05/11 16:24

    私が使ってるoffice365のExcelでは、無理そうでした。
    そもそもツールメニューがありませんですし。
    お役に立てず申し訳ありません。

    キャンセル

  • 2018/05/11 16:29

    ExcelOnlineではなくGoogleのスプレッドシートではないですか?

    キャンセル

  • 2018/05/11 16:29

    Googleのスプレッドシートっていうオチな気がするんですが、違います?

    キャンセル

  • 2018/05/11 16:30

    すみませんよく見たら、そちらでした。

    キャンセル

  • 2018/05/11 16:30

    >dit.さん
    かぶった…w

    キャンセル

  • 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で質問しよう!

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

関連した質問

同じタグがついた質問を見る

  • VBA

    1794questions

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

  • Excel

    1533questions

    Excelは、マイクロソフト社が開発しているデータ集計や分析を行う表計算ソフトの一つです。文書作成や表計算、資料作成などの多彩な機能を備えており、統合パッケージであるMicrosoft Officeに含まれています。

  • Google

    597questions

    Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

  • Google Cloud Platform

    145questions