VBAでExcelの外部取込みデータの更新を行っているのですが、思う通りに動作せず悩んでいます。
初心者なので分かりづらいかもしれませんが、お読み頂き助言いただけますと助かります。
■やっていること
1)あるExcelの表(アンケート結果)を、別のファイルにMS-Queryで取り込んでいます
2)データ元のファイルは毎月更新され、ファイルパスが変わるので、取り込み側で都度「ブックの接続」プロパティを手で書き換え、取り込み直しています。
3)取り込んだ表の「サービス」列中の値に「×」があったら、そのセルを赤く塗り潰しています。
→毎月の2)と3)に相当するマクロを作ったのですが、取り込みはできるものの、塗り潰す所がうまくいきません。
■取り込んでいる表のイメージ
番号 提供時間 料理の味 雰囲気 サービス
---------------------------------------------------
A001 ○ ○ ○ △
A002 ○ ○ ○ ○
A003 × △ △ ×
■マクロ
※取り込んだ外部データ範囲のテーブル名:「T_アンケート結果チェック」
※別の作業の一環で、このマクロ実行前は値はすべて「×」以外になってます
Sub アンケート結果チェック()
Dim sConFile As String
Dim LO As ListObject
Dim C As Range
'処理1:接続先ファイルを選択
sConFile = Application.GetOpenFilename(Title:="今月のアンケート結果ファイルを選択してください")
If sConFile = "False" Then Exit Sub
'処理2:接続情報のDBQ(ファイルパス)を選択したファイルに変更してデータ更新
ThisWorkbook.Connections("con_アンケート結果").ODBCConnection.Connection _
= "ODBC;DSN=Excel Files;DBQ=" & sConFile &
";DefaultDir=Z:\アンケート;DriverId=1046;MaxBufferSize=2048;PageTimeout=5;"
ThisWorkbook.Connections("con_アンケート結果").Refresh
'処理3:サービス列に「×」があったらセルを赤く塗りつぶす
Set LO = ThisWorkbook.Sheets(1).ListObjects("T_アンケート結果チェック")
For Each C In LO.ListColumns("サービス").DataBodyRange
If C = "×" Then C.Interior.Color = vbRed
Next C
End Sub
■状況
・取り込んだデータの「サービス」列中に「×」があっても赤くならない
→処理2のRefreshメソッド実行時点では、Excel画面上のデータは更新されず、
そのため処理3のIF文の判定はすべてfalseになってしまう
・プロシージャが終了した時点で、Excel画面の表示も取り込んだ内容に更新される
・処理3の前にブレークポイントを設定して、マクロを一時停止した状態で
Excelウィンドウをクリックすると、その時点でデータの表示は更新される
→したがって実行を再開すると、想定通り×のところに色がつく
■質問
・処理3に入る前にExcelシート上のデータを更新するには、どんなコードを書いたら良いのでしょうか。
なお塗り潰しだけなら「条件付き書式」でできるよ、ということは承知しています。
(話を単純化してますが、実際は「×」判定後もっと色んな処理をしています)
今回はあくまで、「外部データ更新をプロシージャ実行中にセルに反映する方法」を知りたいと考えています。
長文申し訳ございません。よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
推しミネラルウォーターはありますか?
推しミネラルウォーターがあったら教えてください
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
エクセルで参照しているデータを常に最新の状態にしたい
Excel(エクセル)
-
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
-
4
特定セルの内容を更新したら、その更新日を自動的に表示する方法について
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「ご処理進めて頂きますようお...
-
エクセルで、日付を入力すると...
-
メルカリのメルカードで買い物...
-
月度は何て読みますか?
-
findは動くがfindnextがマクロ...
-
UMLでの例外処理
-
VBAでループ内で使う変数名を可...
-
switch の範囲指定
-
【Excel】特定の文字を含むセル...
-
DoEventsがやはり分からない
-
FFTの結果ついて
-
取り消し線が入った文字を削除...
-
Access チェックボックスでチェ...
-
Excel VBAにて2つの処理を同時...
-
2重のDo~Loopは?
-
Loadイベント中にほかのイベン...
-
お家デートをしててハグを長い...
-
インタラクティブの反対語は?
-
RPGプログラムの*HIVALについて
-
EXCEL VBA マクロ 実行する度に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「ご処理進めて頂きますようお...
-
エクセルで、日付を入力すると...
-
VBAでループ内で使う変数名を可...
-
メルカリのメルカードで買い物...
-
【Excel】特定の文字を含むセル...
-
DoEventsがやはり分からない
-
プログラミング言語についてc++...
-
EXCEL VBA マクロ 実行する度に...
-
UMLでの例外処理
-
switch の範囲指定
-
FFTの結果ついて
-
お家デートをしててハグを長い...
-
VBの質問#if 0 then ってどう...
-
findは動くがfindnextがマクロ...
-
離散時間フーリエ変換について
-
VB.NET Excelを読み込んでDataT...
-
インタラクティブの反対語は?
-
月度は何て読みますか?
-
リョウ・・・量?料?
-
Do~Loopした回数をカウントしたい
おすすめ情報