Access VBA 質問スレ Part2

1デフォルトの名無しさん
垢版 |
2018/12/12(水) 22:14:39.18ID:GF6Qf3Td
Access の VBA に関する質問スレです

質問テンプレ(雛形)は用意しませんが、OSとAccessのバージョンぐらいは必ず書きましょう


前回のスレッド
Access VBA 質問スレ Part1
https://mevius.5ch.net/test/read.cgi/tech/1328536426/
2022/03/10(木) 18:36:45.22ID:y/Xk/sN2
>>487
SELECT 解答
FROM すべてのあり得る盤面
WHERE 今回の条件
だから
まず盤面を1行にして
2523625752622334
と表す

すべてのあり得る盤面は
2523625752622334
2523625752622331
2523625752622314
2523625752622311
 〜
1111111111111111
だけどこれをどうSQL文の中で
表現すればいいのかわからん
2022/03/11(金) 12:30:05.01ID:+z9vFN5I
>>489
>>484の記事を1から読んでこい
2022/05/01(日) 00:28:53.70ID:uZ+uV6s8
VBAのコード内の文字を置換するプログラムをVBAで行うことはできるでしょうか?
置換の組合せが複数あるので一つずつCtrl+Hで操作すると間違いそうなので,
置換前文字列と置換後文字列の配列を書いて,それを順に実行するようにしたいのです.

自分のコード内に当該置換文字列をがでてくるので,その回避も考えないといけないですが

よろしくお願いします
492デフォルトの名無しさん
垢版 |
2022/05/01(日) 07:29:11.23ID:1HGTgNe1
>>491
できるよ
493デフォルトの名無しさん
垢版 |
2022/05/01(日) 07:36:23.30ID:1HGTgNe1
ごめん、AccessVBAスレだった
知らん
2022/05/01(日) 16:14:10.55ID:4P2yloMu
ACCESSにもApplication.VBEがあるっぽいから、エクセルとかと同じようにできるんじゃね
そもそもコード内をそうそう置換するって状況がよくわからんがな
2022/05/01(日) 20:13:11.92ID:uZ+uV6s8
>>494
オブジェクト名を修正すると,名前の自動修正機能で,オブジェクト間の整合性は保たれます.
例えば,Aクエリー内でBテーブルを使用していて,Bの名前をCに変更するとA内のBテーブル名もCに自動的に修正されます.
ところが,コード内でオブジェクト名を引数に使用している場合(DoCmd.OpenQuery()やQeryDef()など)は,自動的に修正されないので
コード内の文字置換で修正するしかありません.
オブジェクト名をより統一的にしたいとか,あるルールで短くしたいなどの事情です.

でも本当にコードを使ってコード内の文字置換できますか?
「エクセルとかと同じようにできる」とのことですが,エクセルのVBAでできる方法を知りません.
496デフォルトの名無しさん
垢版 |
2022/05/01(日) 20:33:27.28ID:XyObubkl
>>494がApplication.VBEってヒント出してくれてるのに自分で調べる気は無いの?
2022/05/01(日) 20:51:07.35ID:uZ+uV6s8
>>496
いままでApplication.VBEとVBAの違いをしりませんでした.
Application.VBEで検索して,オブジェクトであることをしりました.
できそうな気がしてきました.
調べます
498デフォルトの名無しさん
垢版 |
2022/05/01(日) 21:27:48.04ID:q0kLnjNb
>>497
お前みたいな馬鹿は、方法自体間違えていると思うよ
2022/05/01(日) 22:36:20.05ID:uZ+uV6s8
>>498
正しい方法言ってみな。
言えなきゃ超バカ決定。
500デフォルトの名無しさん
垢版 |
2022/05/01(日) 23:10:31.48ID:q0kLnjNb
やっぱり馬鹿だったか
馬鹿に馬鹿と指摘すると怒りだす
2022/05/03(火) 18:13:45.75ID:hABwtxOZ
>>494>>496
497ですが、
Application.VBE.ActiveVBProject.VBComponents(i).codemodule.ReplaceLine(j,"修正後コード文字列")
を使ってできました。
2022/05/03(火) 21:57:49.43ID:uVFGqhpy
>>501
ありがとう。勉強になります。
2022/05/03(火) 23:56:04.39ID:9Zz7qGMa
コードとデータは分離しなさーい!
2022/05/04(水) 01:12:27.06ID:L2QcoKdh
>>503
オブジェクト名はデータにできない
2022/05/04(水) 01:29:47.87ID:T57Ht3+D
名前は文字列だろ!
VBAの提供するオブジェクトは大抵コレクションで管理されているだろ!
お前の作ったオブジェクトも管理できるようにしろ!
初歩だぞ初歩!
2022/05/04(水) 01:39:45.29ID:L2QcoKdh
つまらん
もういいよ
507デフォルトの名無しさん
垢版 |
2022/05/04(水) 03:22:14.79ID:bSJdUNny
やっぱり馬鹿だった
2022/05/04(水) 08:25:20.61ID:L2QcoKdh
>>507
人のこと馬鹿、馬鹿ってほんとにうるさい奴だな

今回のアプリは俺しか使わずオブジェクト名変更も今回限りが確定しているんで、
オブジェクト名をデータ化できるCreateQueryDefなどを使う手間を省いてクエリデザイナーを使っているだけ。

そういう事情も含めて「もういいよ」と書いたんだけど、読み取れんわな。

お前は実生活で他人の事情を汲み取る力が弱くて他人から避けられてるだろう。
実生活では流石に馬鹿と面罵しないとは思うが態度にはでてると思うよ。

エクセルVBAのようにワッチョイ付きならNG登録するんだが。
2022/05/04(水) 12:11:33.62ID:T57Ht3+D
何人登録するつもり?
2022/05/06(金) 14:43:39.68ID:HOAU3QSN
>>508
もういいから馬鹿は黙ってろ
511デフォルトの名無しさん
垢版 |
2022/05/11(水) 09:14:31.47ID:+mNN1hZ/
ここはBKのあつまりでつか?
51244
垢版 |
2022/06/18(土) 22:47:23.35ID:yLkug1TW
味噌も糞もいるのがこういう掲示板の特徴
それが面白ければ来るし退屈なら来ない
文句言うのはカッコ悪い
513デフォルトの名無しさん
垢版 |
2022/06/19(日) 06:53:58.66ID:R9q2ZnJn
>>512
こういうのかっこ悪い
51444
垢版 |
2022/06/19(日) 07:49:57.69ID:ZfwUc+SV
>>513
いやいや本当のイケメンだろうな
2022/06/21(火) 16:34:11.41ID:q4pJaYn5
test
2022/06/21(火) 16:34:30.21ID:q4pJaYn5
アプリケーションタイトルについて質問です。
今使ってるmdbのタイトルが2種類あって、「Access」のものと「ファイル名:データベース-フルパス-Access」のものがあります。

全部後者のタイトルにしたいのですが、設定の仕方がわかりません。
ヤフー知恵袋の「Accessのタイトルバーにファイル名を表示させることはできますか。
Excelでは表示されるのですがAccessでは”Access”としか表示されず少し不便なので、、」
を読むと何の設定もしなくても後者のようになると書いている人がいます。
どうしたらそうなるのでしょうか?

後者のやつは別にAppTitleとかで設定していませんので不思議です。
517516
垢版 |
2022/06/21(火) 17:34:19.49ID:q4pJaYn5
解決しました。
518デフォルトの名無しさん
垢版 |
2022/06/21(火) 19:20:51.51ID:EkCiEQiW
>>517
どうやって?
知りたい
519516
垢版 |
2022/06/21(火) 19:44:50.71ID:q4pJaYn5
>>518
いろいろ試したけど、結論は超簡単。
ファイル→オプション→現在のデータバース→アプリケーションオプション→ドキュメントウィンドオプション→タブ付ドキュメントをon

これでファイル名とパス名が表示されて複数のmdbを起動しても混乱しなくなりました。
520デフォルトの名無しさん
垢版 |
2022/06/21(火) 20:23:15.71ID:QtwFSmmg
OS:win10
Ver:365 16.0

フォルダの中に複数のExcelファイルがあります
accessで全てのエクセルの同一セルの文字をテーブルにまとめたいのです
Accecc vba エクセルの特定のセル
などで検索してみましたが解決に至っていません
どうかお力添えお願いします
2022/06/21(火) 20:46:00.64ID:kU7/2TZz
何がしたいかと、どこまで出来て何がわからないのか詳しくかけ
2022/06/22(水) 10:12:43.83ID:N/5JiATv
>>520
Excelシート全てインポートすればクエリー加工出来ると思うが、、
2022/06/22(水) 10:16:19.65ID:N/5JiATv
>>520
Excelシートリンクでも良いぞ
2022/06/22(水) 10:27:56.84ID:lUHG2pSs
ネ申エクセルからデータを拾いたいとかそんな話じゃね?
CreateObject("Excel.Application")
使って対象ファイル開いて、そっからさきはExcel VBAの範疇やろ
2022/06/22(水) 12:36:20.21ID:N/5JiATv
なんだ
Accessでテーブル化したい、のでは無いのか?
何やりたいのか分からんな
526デフォルトの名無しさん
垢版 |
2022/06/22(水) 15:16:59.53ID:Z6mZqai9
「AccessVBAからexcelファイルのセル参照ってどうやるの?」ていう質問でしょ
527デフォルトの名無しさん
垢版 |
2022/06/22(水) 20:19:24.91ID:rLKMJdnt
質問には答えられるけど
答えるとまた次の質問が来るのが予測出来るからまんどくせ
2022/06/23(木) 06:46:56.49ID:nErcbU9U
>>527
スレに来ないと良いよ
2022/06/23(木) 07:36:49.86ID:xe+L83Np
>>521-523
なにをやりないか再度確認してコード見直していたら不具合点見つかって前進しました…
>>525
やりたいのはこれで30個程度のエクセルがあって全てフォームは統一されています
a3とb4とw30の値をテーブルにズドンと引っ張りたいのです

もうちょっと頑張ってみます
遅くなってごめんなさい
2022/06/23(木) 12:13:27.06ID:jwJvRDT9
ACCESS VBA EXCEL CELLでクグルと沢山出て来ますね。
ACCESSからEXCEL開いて操作できると便利です、頑張ってください。
2022/06/23(木) 12:56:15.59ID:uoofWh9e
>>529
CreateObject("Excel.Application")でエクセルを操作できるようにする

対象とするシートからa3とb4とw30の値を取得して変数 X Y Z に格納する
変数 X Y Z の値をAccess のテーブルに追加する
この二つの処理を全てのシートにループで行う

釣りが終わったExcel オブジェクトを閉じる
Access のオブジェクトの閉じる

これでいけるんじゃね?
2022/06/24(金) 06:07:38.19ID:X+tgL9yK
>>531-532
ありがとうございます
こう書くとすごくわかりやすいですね

テーブル追加やLOOPは調べて書き方を学べそうなのでやってみます!
533デフォルトの名無しさん
垢版 |
2022/06/26(日) 13:37:45.11ID:DTfGvOZF
https://www.youtube.com/watch?v=jppnWu6am3Q
2022/06/26(日) 22:59:47.94ID:Ter0iV/V
たびたびすみません
ばしっとフォルダ内のファイル名を取得することはできました
>CreateObject("Excel.Application")でエクセルを操作できるようにする
これの意味がようやくわかりました ありがとうございます

C:\Users\sanae\Desktop\vba\Book1.xlsx というExcelファイルのa3を変数に入れようとしているのですが
ぐぐったところファイルパスをつける書きかたが参考にできるページがみあたらず詰まっています
(このあたりにファイルパスとかシートとかを指定して)range(3.1) みたいなやり方かなあなんて思っているのですがどれもエラーになっちゃいました
参考になるページでもご教示いただければ幸いでございます
2022/06/27(月) 00:21:56.25ID:LR8Jvthl
>>534
http://officetanaka.net/excel/vba/file/file01.htm

を参考にしてください。

Sub Sample1

set mybook=myexel.Workbooks.Open "C:\Users\sanae\Desktop\vba\Book1.xlsx"
x=mybook.worksheets(1).range("A 3")

X の値をテーブルに書き込む

End Sub

myexelはクリエイトオブジェクトで作ったエクセルオブジェクトね
あと変数は適当に定義しておいてね。
536デフォルトの名無しさん
垢版 |
2022/06/27(月) 01:42:38.20ID:Yed1CrTu
>>535
おおお
できてきました とても進みました
・フォルダを指定してファイル名を取得
・変数XYZに特定のセルの値を取得
2022/06/27(月) 01:45:22.88ID:Yed1CrTu
すみませんCTRL+エンターで送信になってしまいました
・フォルダを指定してファイル名を取得
・指定したシートから変数XYZに特定のセルの値を取得
・XYZの値をテーブルに追加
超進みました

後は指定したシート名を持たないファイルに遭遇した時にどんなエラーになるのかが気になりますので
近々時間みつけて頑張ろうと思います

ありがとうございました!超ハッピー!
538デフォルトの名無しさん
垢版 |
2022/06/27(月) 01:59:55.53ID:YAQt7RYR
馬鹿は二度と来るなよ
2022/06/27(月) 08:41:44.29ID:yeeW9wqV
VBAでやらなくてもテーブルimportで出来るやろ
無駄な努力だな
2022/06/27(月) 11:56:31.55ID:LR8Jvthl
>>539
ブック数が多いから VBA でやりたいんじゃないの?
インポートでできる量だったら手でコピペの方が早いだろ
2022/06/27(月) 15:59:24.18ID:jKYPD+Yx
対象のExcelファイルが固定なのか、頻繁に入れ替わるかどうかにもよるわな
542デフォルトの名無しさん
垢版 |
2022/06/27(月) 20:22:09.19ID:UdQiWAN3
どなたか教えてください。

売掛金消し込みのマクロを作成しています。VBAでソルバーを自動化したいと思っています。

目的セル、制約条件の参照セルの開始行が40行ごとに下がっていき、指定値は数値ではなく、セルを指定したいです。

とりあえず、全部の変数をvariant型にしてますが、なかなか上手くいきません。
2022/06/27(月) 20:42:56.65ID:NFVjaUBh
なんでAccessVBAスレにまで書いてるんだよ
544デフォルトの名無しさん
垢版 |
2022/06/28(火) 12:01:23.56ID:W8L8uteA
こんな奴が作るプログラムで金勘定とか笑えるわ
己を知らないって馬鹿の特徴なんだよな
2022/06/28(火) 12:08:16.40ID:S7aFTH1N
>>542
Access VBAスレでExcelの質問するなよ
2022/06/28(火) 12:53:23.92ID:illrnTHm
EXCELで記録したVBAをACCESSで実行するとEXCELはXlmxにしなくても良いからじゃないの?
ソルバーは使い方わからんのでなんにも言えなくてスマン。
2022/06/28(火) 13:14:48.17ID:v0i+TmEN
>>546
Excel VBAスレみればなにがあったのか分かるよ
548デフォルトの名無しさん
垢版 |
2022/06/28(火) 21:08:59.28ID:i28fB/zi
昨日アホな質問した541です。

accessスレにexcel VBAについて投稿してしまい、すみませんでした。

VBA初心者なので、よくわからずに投稿してしまいました。
549デフォルトの名無しさん
垢版 |
2022/06/29(水) 10:01:41.27ID:Es0nfTu8
初心者を言い訳にする香具師は同じ失敗を繰り返す
2022/06/29(水) 12:18:55.14ID:C7zOwXa/
狭量にすぎる
2022/06/29(水) 12:31:17.45ID:WL8L6KaP
スレを間違ったことではなくマルチが問題なのだがな
2022/06/29(水) 13:27:42.53ID:tPok425v
>>551
それだけ焦ってたんでしょ。Excel VBA で反応がなければ藁をもすがる気持ちで アクセス VBA で聞いたんじゃない。
広い気持ちで
553デフォルトの名無しさん
垢版 |
2022/06/29(水) 13:50:40.09ID:Es0nfTu8
x VBA初心者
o 5ch初心者
o パソコン初心者
o コミュ障入門者(上級)
554516
垢版 |
2022/06/30(木) 01:00:46.93ID:1OP/W/CA
DoCmd.OpenReport "レポート名", acViewPreview
DoCmd.PrintOut acPrintAll, , , acHigh, 枚数

新規レポートにラベルを貼っただけものだと希望どおりの枚数が印刷される.
しかし,別のレポートだと常に1枚しか印刷されない.
ネットでも同じ報告を確認した.バグ説もある.

皆さんはどうですか?やっぱりバグですかね?
555516
垢版 |
2022/06/30(木) 16:01:17.27ID:1OP/W/CA
解決した.
デコンパイルとコンパクトしたらいつの間にか設定した枚数が印刷されるようになった.
accessはマジで面倒くさいなあ.
デコンパイルとコンパクトの待ち時間をを返して欲しいよ
2022/06/30(木) 19:00:33.50ID:PX9/MxY9
デコンパイル、知りませんでした。
2022/06/30(木) 20:22:38.17ID:1+oYjPxt
デコンパイル、昔は割と鉄板の解決方法だったんだけどね
それでだめなら新規作成して全モジュールインポートとかもあったな

最近は必要性が減ったけど、まだたまにはあるんだな
558516
垢版 |
2022/06/30(木) 22:53:16.59ID:1OP/W/CA
コンパクトだけでも良かったのかも知れないが,習慣で両方やることにしている
ついいましがたも.Docmd.OpenReportのOpenArgsがレポートに渡らなくて困っていたが,コンパクトをしたら作動した.
終了時にコンパクトするオプションがあるくらいだから頻繁にやるべきなんだろうね.
コード書いているときは非常に頻繁に破損するからね.
2022/06/30(木) 23:46:30.14ID:1+oYjPxt
あれはデータ領域を圧縮するのが主で、コード部分にはあまり影響しなかった気がするが
最近のアクセスでコードが破損するのはだいぶ減ったと思うが
VBEからコンパイルするだけで解決してたんじゃないか?
560516
垢版 |
2022/07/01(金) 00:40:02.55ID:SILFs/Ha
くわしいことはわからないが,挙動不審が治ることがあるんだよねえ
とにかく,試行錯誤していると必ずと言っていいほど,壊れるよねえ.
メモリーが不足していますとか出始めると,その日のうちに全フォーム消失とか起こるからなあ.
2022/07/01(金) 10:45:11.72ID:x9gnk4T5
試行錯誤の過程のほとんどを貯め込むからな 設定で「終了時に最適化」で、都度終了を心掛けるか
大幅な改修の度にコンパイルのクセを付けるか ファイルサイズに気を付けて、「こんなサイズのはずは無い」ってな時は要注意
 で、それは、お道具の使い方が雑、間違ってるってだけで、すぐAccessのせいにする連中はお里が知れる ってこと
562516
垢版 |
2022/07/07(木) 15:33:38.95ID:9tJXVGoG
下のコードでmdbのディレクトリが表示されると思いきや、
ディレクトリ Documents
フルパス C:\Users\MyName\Documents

が表示された。vbsならscriptの存在するディレクトリだからmdbの存在するディレクトリが表示されると思ったのに、違う。
このことを説明してある資料ありますかね?


Sub test()
Dim fso
Dim objfolder
Set fso = CreateObject("Scripting.FileSystemObject")
Set objfolder = fso.GetFolder(".")
Debug.Print "ディレクトリ", objfolder.Name
Debug.Print "フルパス", objfolder.Path
End Sub
2022/07/07(木) 16:12:50.20ID:N4ENiOaQ
>>562
mdb/accdbファイルの場所が欲しいのなら
CurrentProject.Path
を使おう
CurDir$や>>562の例なんかで返されるカレントディレクトリはファイルダイアログとかで開いたフォルダになるっぽい
その辺の仕様に関する資料は知らんけど
2022/07/07(木) 19:57:05.70ID:V/fQnZ1U
そもそも、
>vbsならscriptの存在するディレクトリ
が間違ってる気がするが

カレントディレクトリの概念って最近は説明されてるの見ないなぁ
GetFolder(".")が返してるのはカレントディレクトリ(からの相対パスで自分自身)
カレントディレクトリはACCESS.EXEの場所や.MDBファイルの場所とは別に存在する

まあMDB開くときはそこをカレントにする場合が多いけどな
つねに一致してるとは限らん
565516
垢版 |
2022/07/07(木) 20:26:42.06ID:9tJXVGoG
>>564
> そもそも、
> >vbsならscriptの存在するディレクトリ
> が間違ってる気がするが

VBSで稼働していたスクリプトをVBAに移植している際に気づいたので、正しいと思います。
スクリプトを任意のフォルダにコピーしてそのフォルダ内のファイルを一括処理するのに使っていましたので。
2022/07/07(木) 20:31:06.22ID:ty1oWU7C
chdirで変えられちゃうけど
567516
垢版 |
2022/07/07(木) 20:55:49.31ID:9tJXVGoG
ユーザはおいら1人だからいいのです。
2022/07/07(木) 21:30:15.27ID:V/fQnZ1U
いやだから、scriptの存在するディレクトリじゃなくて、
カレントディレクトリが表示されてるって話なんだがな
たまたまそれが同じだっただけだ

ここ理解しないと思ったディレクトリが表示されない理由が理解できないぞ
569デフォルトの名無しさん
垢版 |
2022/07/07(木) 22:24:24.15ID:rKn8i4wF
馬鹿に何を言っても無駄な例だぞ
2022/07/08(金) 10:33:00.73ID:aHYxM19P
>>565
そのスクリプトをショートカットにして、
作業フォルダを変えて動かしてみたい
2022/07/08(金) 12:10:02.96ID:/znuHP85
カレントディレクトリみたいな、あやふやなものを使ってはいけない。
これが使えるのは、絶対に変化しない場合だけ

起動時に、特定のフォルダを指定するとか、
あらかじめ定数などに保存しておく
2022/07/08(金) 12:16:33.93ID:/znuHP85
例えばデスクトップに、以下のショートカットを作ると、

WSL2 で、Ubuntu 18.04 を起動して、
その /home/ユーザー名/test ディレクトリを、VSCode で開く

リンク先
C:\Windows\System32\wsl.exe code .

作業フォルダ
\\wsl$\Ubuntu-18.04\home\ユーザー名\test
2022/07/08(金) 12:30:53.39ID:PreZKXp3
もはやAccess VBAとは関係ない話になってるし、元質問者は聞く耳持たないみたいだから
これ以上続ける意味無いよ
574デフォルトの名無しさん
垢版 |
2022/07/11(月) 11:04:56.16ID:1W23UOpt
>>562
fso使ってるんだから当たり前
2022/07/12(火) 17:20:09.84ID:xDQ7ywi9
>>574
なぜ「fsoを使うと」なにが、「当たり前」なんだい?
576デフォルトの名無しさん
垢版 |
2022/07/13(水) 18:08:17.37ID:sooqvjiy
7月12日のWindows Updateを実施した端末で軒並み「要求されたタイプ ライブラリまたはウィザードは VBA プロジェクトではありません。」
というエラーが出てAccessで作ったものが起動できない症状が出てるんだけど、何か知ってる?
ちなみにAccess Runtimeを再インストールすると直る。修復ではダメ。
577デフォルトの名無しさん
垢版 |
2022/07/13(水) 18:15:29.57ID:sooqvjiy
>>576 書き忘れたけど手元で問題が発生しているのはAccess Runtime 2013 32bitの端末。
OSはWin8.1とWin10の両方で発生してる。
2022/07/13(水) 19:12:40.99ID:PtV2v+lq
うちの環境とほぼ同じですね、まだ発生してないけど明日あたり起きるのかな。
runtimeの入れ直しですね、了解っす。
579デフォルトの名無しさん
垢版 |
2022/07/14(木) 09:57:45.69ID:gGJjrJSy
>>576
特定した。
KB5002121を入れると症状が発生する。
Access Runtimeを再インストールしても再度Windows Updateを実施すると元に戻るから
KB5002121をブロックしないとダメだ。
58044
垢版 |
2022/07/14(木) 12:52:21.90ID:Fq9OF9ol
迷惑な話ですねえ。
MSのプログラマーがアホなのは今に始まったことじゃないけど
2022/07/14(木) 18:41:39.80ID:Zi9qyvS+
昔EXCELのVBAで似たような話が合った気がするな
その時はテンポラリディレクトリの掃除したら起動するようになったはずだから
いちど試してみては
582デフォルトの名無しさん
垢版 |
2022/07/18(月) 12:31:42.55ID:1omE+gQa
MSは自社製品のテスト駆動開発すらしてない
テストが面倒になるとサポート打ち切り
583デフォルトの名無しさん
垢版 |
2022/07/18(月) 13:02:03.33ID:dNd6yRIh
>>582
それソースあるの?
2022/07/19(火) 13:18:07.18ID:4mWHj4S5
2022年7月パッチで「Microsoft Access」に問題、バージョンが異なるとファイルが開けない
https://forest.watch.impress.co.jp/docs/news/1425748.html
>異なるバージョンの「Microsoft Access」で作成されたデータベースファイル(ACCDE/MDE)を開こうとすると、「要求されたタイプ ライブラリまたはウィザードは VBA プロジェクトではありません」というエラーが発生する場合がある
2022/07/20(水) 10:36:39.60ID:Rwr2SDqT
Formを変数にSetするとき下の二つのやり方のどちらが速いか試したら、結構まちまちなんですよね。
後者はEarly Bindingだと思うんだけど、ループさせると前者が速いことも結構あって不思議だ。
だれかこのあたりの事情をご存じの方いますか?

Dim F As Form
Set F = Forms!FormName

Dim F As Form_FormName
Set F = Forms!FormName
586デフォルトの名無しさん
垢版 |
2022/07/20(水) 11:16:41.39ID:2HHkZJi9
>>584
runtime版でそれ出たな、試行錯誤でruntime2016からruntime365に変えたら動いたw事がある。
587デフォルトの名無しさん
垢版 |
2022/07/20(水) 15:41:40.93ID:qJwz0nM8
runtimeは糞
2022/07/20(水) 18:29:58.22ID:BaO5YoZA
>>585
あってるかどうかは知らんが

!は実行時に列挙する気がするんだが
後者は型チェックと変換が入るから後者のほうが遅いと思う
前者も入るかもしれんが、そうなるとForm型とForm_FormName型でどっちのキャストが早いかで
結局やっぱり後者が遅い気がする

どっちにしたってFは型指定されているので事前バインドだが、
それが差に出るのはFのメンバーを使うときだぜ

まあ、なんにしても誤差レベルだと思うが
レスを投稿する

5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況