- ベストアンサー
エクセルでのアクセスからのデータ抽出のVBAコード
- エクセルでのアクセスからのデータ抽出のVBAコードの実行時エラーの原因と解決策を説明します。
- VBAを使ってエクセルでのアクセスからデータを抽出する際に発生する実行時エラーについて解説します。
- エクセルでVBAを使用してデータ抽出を行う際に発生する「実行時エラー3705」の原因と対処法を紹介します。
- みんなの回答 (8)
- 専門家の回答
質問者が選んだベストアンサー
> B4の値によっては①~⑦や、①~⑩まで等、⑮に満たない時もあります その時の値が何で(その値によってどこの何が変化するのか)それで①~⑦や、①~⑩とかをどの値で決めているのかが分からないだろうといってるのですが、そんなこともいちいち細かく言わなければ説明できないなら自分で考えてください。
その他の回答 (7)
- kkkkkm
- ベストアンサー率66% (1719/2589)
> Range("B4").Valueに入る値が変わると、 > 取得するデータ数が変化します。 この状態をどのようにして実装しているのか不明。 この部分を説明せずに以下を聞くのはムチャぶりというもの。 > Forの値が17以下だった場合でもエラーが出ずに処理できるようになればいいのですが。 16行に、Vlookupで値を表示、一致が無ければ""みたいな式など何らかの式が入っていなければ Dim LastColumn As Long LastColumn = Cells(16, Columns.Count).End(xlToLeft).Column For j = 4 To LastColumn 実際の操作 Next 式が入っている場合、不要なセルにデータの表示が無い""の場合 For j = 4 To 17 If Cells(16, j).Value = "" Then Exit For End If 実際の操作 Next
- kkkkkm
- ベストアンサー率66% (1719/2589)
Cells(16, j).Value ですから jはシートの列指定の変数だと思いますが。 For J = 4 to 10 で正常なら D16からJ16までしかデータが無かったという事じゃないですか。
補足
>For J = 4 to 10 >で正常なら >D16からJ16までしかデータが無かったという事じゃないですか。 今回確認したパターンでは、D16からJ16までしかデータない状態なのですが、 「GetName = Range("B4").Value & "_" & Cells(16, j).Value」のRange("B4").Valueに入る値が変わると、 取得するデータ数が変化します。 当初より提示させて頂いたFor J = 4 to 17というのは取得データ数の最大数なので、 もしForの値が17以下だった場合でもエラーが出ずに処理できるようになればいいのですが。
- kkkkkm
- ベストアンサー率66% (1719/2589)
> >とりあえずActiveSheet.Nameを実際のシート名にして > →どちらも wSheetName = ActiveSheet.Name でstop ActiveSheet.Nameを実際のシート名にしたら wSheetName = ActiveSheet.Name というコードはありえませんが…。 > →どちらも i = 20の前でstop 前って…なにもコードの無いところでは止まらないと思いますが…。 きちんと状況を説明できないみたいですね。回答した手順もちゃんと実行できていなのではないでしょうか。 adoRS.Closeを 略 adoRS.MovePrevious Loop j = j + 1 adoRS.Close '←ここに入れましたか? Loop 略
補足
>adoRS.Closeを >略 >adoRS.MovePrevious >Loop >j = j + 1 >adoRS.Close '←ここに入れましたか? >Loop アドバイス通りに入れたら、2巡目以降も動きました。 自分は下記のように訂正していました。 adoRS.MovePrevious Loop j = j + 1 adoRS.Close Set adoRS = Nothing adoCON.Close Set adoCON = Nothing Loop アドバイスの意味を間違えて捉えていたので、見当違いの回答になってしまい大変失礼しました。 ですが、希望通りに動くようになりました。ありがとうございます。 ただ1つ、For J = 4 to 17 が完了する前にテーブルから抽出できるデータが無くなってしまうと、 「3021 アプリケーション定義またはオブジェクト定義エラー」 と出てしまいます。 仮にFor J = 4 to 10 としたらエラーが出ずに処理が完了しました。 Forの回数をレコードの数によって変化させるということはできますでしょうか。 お手数ですが、こちらもご教示頂きたいです。
- kkkkkm
- ベストアンサー率66% (1719/2589)
> どのパターンも同じところで同じエラーが発生してしまいます。 wSheetName = ActiveSheet.Name を無くしたパターンでは同じところはないはずですが。 wSheetName = ActiveSheet.Name がありませんから同じところでエラーになるとはどういうことでしょう。 また Do Until j = 18の前に置いても その前の wSheetName = ActiveSheet.Name でエラーなのですか? としたら一回も実行されないということになります。 とりあえずActiveSheet.Nameを実際のシート名にして試してみてください。
- kkkkkm
- ベストアンサー率66% (1719/2589)
No2の訂正です。 For j = 4 To 18 は For j = 4 To 17
補足
ご回答ありがとうございます。 ご回答頂いた内容に変更し確認してみましたが、どのパターンも同じところで同じエラーが発生してしまいます。
- kkkkkm
- ベストアンサー率66% (1719/2589)
No1の蛇足です。 本題とは関係ありませんが j = 4 Do Until j = 18 : j = j + 1 Loop は For j = 4 To 18 : Next で良さそうな気がします。
- kkkkkm
- ベストアンサー率66% (1719/2589)
adoRS.Open strSQL, adoCON, adOpenDynamic がCloseしないままに再度実行されますが adoRS.Closeを j = j + 1 の後の Loop の前に置いた方がいいような気もします。 あと wSheetName = ActiveSheet.Name を Do Until j = 18 の前に置くとか wSheetName = ActiveSheet.Name をやめて With Worksheets(wSheetName) を With ActiveSheet にしてみてはいかがでしょう。
補足
アドバイス頂いた内容のエラーを再度確認しました >adoRS.Closeを >j = j + 1 >の後の >Loop >の前に置いた方がいいような気もします。 >とりあえずActiveSheet.Nameを実際のシート名にして →どちらも wSheetName = ActiveSheet.Name でstop >wSheetName = ActiveSheet.Name >を >Do Until j = 18 >の前に置くとか >wSheetName = ActiveSheet.Name >をやめて >With Worksheets(wSheetName) >を >With ActiveSheet →どちらも i = 20の前でstop どちらも同じ箇所と伝えていましたが、改めて確認したところ、違っておりました。大変失礼しました。
補足
ご提示頂いた内容を試したのですが、ご指摘の通り私の説明が悪く、違う回答を求めてしまったようです。大変申し訳ありません。 D16:R16までは予め①~⑮までの値が入力してあり、B4の値と組み合わせ、1巡目の処理ではtest_①と一致するものを抽出、 2巡目ではtest_②と一致するものを抽出と、①~⑮までを1つづつ変えながら繰り返し抽出を行いたいのですが、 B4の値によっては①~⑦や、①~⑩まで等、⑮に満たない時もあります。 今は⑮まで満たない場合は、エラーで停止してしまうので、 ⑮まで満たない場合でもエラーが出ないで停止するようにしたいのです。 上手く説明することができず、ご迷惑をお掛けしてしまっておりますが、ご教示をお願いします。