🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
VBA

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

Q&A

1回答

1749閲覧

表の中にある黄色のセルだけ抽出したい

oldlingo

総合スコア0

VBA

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

0グッド

1クリップ

投稿2020/12/26 13:28

前提・実現したいこと

マクロ初心者です。
表の中にある黄色のセルだけ抽出したのですが、
下記マクロだとA列のものだけしか出てきません。他のれつの黄色のセルも全部抽出するには、
どうすればよいのでしょうか?御教授お願い致します。

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

エラーはありません

該当のソースコード

Sub 色抽出()
ActiveSheet.AutoFilterMode = False
Range("A1").AutoFilter _
Field:=1, _
Operator:=xlFilterCellColor, _
Criteria1:=RGB(255, 255, 0)
End Sub

試したこと

ここに問題に対して試したことを記載してください。

Field:=の番号をかえると抽出数が増えますが全部は抽出来ません

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

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

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

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

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

radames1000

2021/01/01 01:28

最初の表と、最後に臨む結果を手作業でも作ってみて提示してください。
guest

回答1

0

VBAで作業列を使ってみました。

データ範囲の右隣りを作業列として、そこに行内に黄色のセルがある場合に"〇"を代入して、作業列を対象にオートフィルターかけます。

vba

1Sub 色抽出() 2 ActiveSheet.AutoFilterMode = False 3 4 Dim r As Range 5 For Each r In Range("A1").CurrentRegion.Rows 6 Dim c As Range 7 For Each c In r.Cells 8 If c.Interior.Color = RGB(255, 255, 0) Then 9 r.Cells(1, r.Columns.Count + 1).Value = "〇" 10 Exit For 11 End If 12 Next 13 Next 14 15 With Range("A1").CurrentRegion 16 .AutoFilter _ 17 Field:=Range("A1").CurrentRegion.Columns.Count, _ 18 Criteria1:="〇" 19 End With 20End Sub

 

サンプルを作成して上記処理を実行した結果のキャプチャー

イメージ説明

投稿2020/12/26 16:42

編集2020/12/27 08:56
hatena19

総合スコア34073

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

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

oldlingo

2020/12/27 08:16

早々に回答頂き恐縮至極です。ありがとうございます。 実行したところエラーなしに動きましたが、黄色の抽出が0件になりました。 作業列のすぐ横のシートが前回シートの貼り付けで、その横が今回シート貼り付けになっています。 このファイルそのものは何処かに出して作ってもらった物らしく、構造がよく分かりません。やたら計算式が入っています。 前回シートと今回シートと比較して差分が作業列に黄色で表示されているのですが、 今回やりたい事はその黄色になったセルが混じっている行だけ抽出したいという目的です。 VBA初心者で、ネットで調べながらトライしてみているのですが、いまのところ全件抽出することが出来ません。 急ぎませんのでまた時間のある時ご教示お願い致します。
hatena19

2020/12/27 08:46

こちらで作成したサンプルでは問題なく動作しているので、提示された情報だけでは、うまくいかない原因は分かりません。 > 作業列のすぐ横のシートが前回シートの貼り付けで、その横が今回シート貼り付けになっています。 この部分については何を言っているのか意味が分かりません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問