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

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

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

DLL(Dynamic Link Library)とは、他のモジュールからも使用する事が出来る、関数とデータが格納されているモジュールのことです。

VBA

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

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

2回答

10370閲覧

Excel VBAの32bit版と64bit版から共通のdllを呼び出す方法について

退会済みユーザー

退会済みユーザー

総合スコア0

DLL

DLL(Dynamic Link Library)とは、他のモジュールからも使用する事が出来る、関数とデータが格納されているモジュールのことです。

VBA

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

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2021/04/09 10:23

編集2021/04/09 11:37

32bit版のdllを64bit版のExcelから呼び出すとエラーになります。
逆に64bit版のdllを32版のExcelから呼び出してもやっぱりエラーになります。
仕方がないのでdllを2つ作ってリリースしています。
その辺りに詳しいユーザーなら問題なく使い分けて頂けると思いますが、パソコンの初心者にもわかるような使い分けをしてもらう手段が難しく、出来れば共通のdllにしたいと思っています。
どうすれば良いでしょうか?

ちなみにエラーはdllのロードで発生しているようです。

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

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

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

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

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

m.ts10806

2021/04/09 10:45

ご自身が初心者なので分かるのでは。
guest

回答2

0

ベストアンサー

DLLは別の名前にしといて、Excelのほうでbitを判定してそれぞれ呼び分けるようにすればいいんでは

参考
32bit, 64bit共通で使えるdllを作りたい

投稿2021/04/09 11:46

編集2021/04/09 11:49
y_waiwai

総合スコア88042

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

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

退会済みユーザー

退会済みユーザー

2021/04/09 13:13

出来ました。 いつもありがとうございます。 頭いいなぁと感心しました。
guest

0

エラーの種類がわかりませんが、
呼び出した処理が想定外の挙動をするということではなく、
APIのルーチンそのものが呼び出せないならば、
下記のようにAPI呼び出し時に
条件付きコンパイル引数を用いて環境ごとに条件分けする方法があります。

vb

1#If Vba7 Then 2Declare PtrSafe Function GetActiveWindow Lib "user32" () As LongPtr 3#Else 4Declare Function GetActiveWindow Lib "user32" () As Long 5#End If

下記のサイトに条件付きコンパイル(32ビット64ビットの互換性)について
詳細に述べられていますのでご参照ください。

条件付きコンパイル(32ビット64ビットの互換性)

投稿2021/04/09 11:18

dede_20191130

総合スコア4

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

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

退会済みユーザー

退会済みユーザー

2021/04/09 11:29

いや、そこまで古いものを今更サポートしなくてもいいけど、64bit版の Excel 2019 と 32bit版の Excel 2016 の違いを吸収出来るdllを作ることが出来ずに困っています。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問