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

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

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

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

解決済

1回答

538閲覧

マクロで一つのセルに複数文字が入っている時の抽出・背景の色付け方法

matsudesuyo

総合スコア4

VBA

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2021/08/04 12:51

前提・実現したいこと

A:ウ
P:ケ

と一つのセルに入力したときに「ウ」「ケ」それぞれの背景に色をつけたい

*用途
16日始まりのシフト表です
シフトの管理が大変で抜け漏れが生じるので、割り振った際に「この店舗は割り振り済み」とわかるよう色が付く仕組みにしたいです

イメージ説明
*補足
C12C37まで人の名前が入っています
C31
C58までは店舗名が入っています
16日(月)はJ列
店舗名のところは例えば、J38にAMなどの割り当て、J39に詳細な時間が入るようにしてます

発生している問題・エラーメッセージ

現状のソースコードでは先に該当する「ウ」しか背景に色がつきません。 これを「ウ」「ケ」それぞれの背景に色をつけたいのですが、うまくいきません。 条件付書式では膨大で面倒になってしまうので、マクロで何かいい方法はありますでしょうか?

該当のソースコード

Dim i As Long Dim j As Long Dim k As Long For i = 12 To 37 For j = 10 To 40 For k = 38 To 39 If Cells(i, j) Like "*ウ*" Then Cells(k, j).Interior.Color = RGB(220, 220, 220) ElseIf Cells(i, j) Like "*ケ*" Then Cells(k + 2, j).Interior.Color = RGB(220, 220, 220) End If Next k Next j Next i End Sub

試したこと

FINDメソッド、別シートにリストを作って照らし合わせるなど。いろいろ試してみましたが、さっぱりでした。。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

こうですか?

VBA

1 If Cells(i, j) Like "*ウ*" Then Cells(k, j).Interior.Color = RGB(220, 220, 220) 2 If Cells(i, j) Like "*ケ*" Then Cells(k + 2, j).Interior.Color = RGB(220, 220, 220)

投稿2021/08/04 13:32

jinoji

総合スコア4592

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

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

matsudesuyo

2021/08/04 14:22

できました!!半日ずーっと悩んでたのですが…シンプルな方法でできるんですね!勉強になりました!とても助かりました。ありがとうございます!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問