初心者です。はじめまして
お世話になります。
概要:C言語で作成したDLLをVBAで呼び出す。
タイトルの通り、C言語で作成したDLLをVBAで呼び出したいのですが、うまく
呼び出すことができず、「エラー番号:49 DLLを正しく呼び出せません。」
というエラーが返ってきてしまいます。
DLLの作成手順もしくはDLLの呼び出し方でおかしな所があればご指摘頂けない
でしょうか?
C言語のDLL、作成手順は以下の通りです。
DLL作成環境:Visual C++ 6.0
DLL作成手順-----------------------------------------
(1)プロジェクトをDLL用に作る
新規作成→プロジェクト→Win32 Dynamic-Link Library→空のDLLプロジェ
クト
(2)ファイル追加
ソースファイル+すべてのヘッダファイルを追加
(3)DLLを出力対象の関数に「_declspec(dllexport)」をつける
例)-------------------------------------
_declspec(dllexport) short dlltest
(char *str1,
char *str2)
---------------------------------------
(4)char を unsigned char へ変換する(/J コンパイルオプション)
(5)プロジェクトをデバッグモードからリリースモードに切り替える
(6)ビルド実行
(7)「Release」配下に.dllとlibができる。
-作成手順完-----------------------------------------------------
実際のVBAのDLLの呼び出しは以下の通り行っています。
-AccessVBAにてDLLの宣言及び、呼び出し-------------------
'呼び出し宣言
Public Declare Function dlltest _
Lib "C:\Project\Dlltest\Release\dlltest.dll" _
(ByVal st1 As String, _
ByVal st2 As String) As Integer
'DLL呼び出し
KEKKA = dlltest(string1, string2)
-呼び出し完------------------------------------------------
これで実行するとエラーが返されていまいます。
なにぶん、初心者で今回初めてVBAでのプログラミングを行っているので観点
の抜けなどが多分にあると思われます。
どんな小さなことでもご指摘頂けないでしょうか?
宜しくお願い致します。
No.1ベストアンサー
- 回答日時:
VC側ですが 呼び出し規約を変更しないといけません
また C++(cpp)拡張子で組んであるなら extern "C"でくくるなどのひつっようがあります
外部公開用の名前が _関数名@引数のバイト数といった変換がなされるので Access側で Aliasを使って整合を取るか DEFファイルによるエクスポート名を指定しましょう
これらを踏まえて
DLL側は
short __declspec( dllexport ) __stdcall dlltest( char* str1, char * str2 )
といった具合にします
CPPファイルなら
extern "C" { // これを使って CPP命名規則を抑止します
short __declspec( dllexport ) __stdcall dlltest( char* str1, char * str2 )
{
// 関数本体
}
}
DEFファイルは
LIBRARY DLLファイル名
EXPORTS
dlltest
といった具合です
# DLLファイル名は適宜修正してください
redfox63様
動きました!!!本当にありがとうございます。
私の場合はC++ではなくCで作成したものでしたのでアドバイスの通り
short __declspec( dllexport ) __stdcall dlltest( char* str1, char * str2 )
と記述し、DEFファイルを作成しただけで動きました。
ググってもほとんど明確な答えになるものがなかったので本当に助かりました^^
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(プログラミング・Web制作) IT初心者です 仕事で、vb.netで作成されたdllをvbaで呼び出すプログラムを作成しろと言われ 1 2023/03/27 08:22
- フリーソフト cygewf-2.dllがない、と表示され、ダウンロードしたファイルが動作しない 2 2023/03/27 11:05
- Windows 10 IT初心者です! powershellで以下のようなエラーが出ました オブジェクト参照がオブジェクト 1 2023/05/17 11:30
- C言語・C++・C# Windows Formアプリからコンソールを呼び出して文字を出力させたい 8 2023/05/09 10:53
- ノートパソコン .dllファイルがありませんと表示される 5 2023/04/30 03:03
- その他(コンピューター・テクノロジー) パソ粥が壊れてしまい。 新しく買ったパソコンに Amplitued5 Max をダウンロードインスト 1 2022/05/22 00:33
- Excel(エクセル) 【VBAファイル移動】2つのマクロを順に実行。1つ目のマクロが実行不可⇒2つ目が実行不可となる件 2 2022/07/29 12:17
- その他(ソフトウェア) MMD PMXエディタ プラグイン 押せない はじめまして。MMDについて質問させていただきます。 7 2022/05/04 15:53
- その他(プログラミング・Web制作) Pythonの作業環境・作業フォルダの迅速な設定・指定方法 3 2022/04/01 07:55
- その他(プログラミング・Web制作) python OpenPyXLを使って出力結果をエクセルに書き込み 2 2022/06/04 19:46
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C#のクラスをVB.netで使用したい!
-
VB.NETで他のプロジェクトで作...
-
ACCESSのEXEを作るのは可能...
-
コンパイルするときに、ファイ...
-
VC++でexeファイルが作成できま...
-
VB6.0
-
エラーの原因は?「この関数の...
-
VB6で、非表示モジュール(?)の...
-
static宣言の共有
-
VC++でプロジェクト名の変え方...
-
*.bsc *.exp??
-
Bccコンパイラについて
-
VisualBasicを保存するときにで...
-
他の.CPPファイルに定義した関...
-
libssh2のインクルード
-
srand48? drand48?
-
printfで全角カタカナが文字化け?
-
VB6 exeファイルのプロパティの...
-
C++超初心者質問
-
VC++(VS)でコンソールアプリ(...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VB.NETで他のプロジェクトで作...
-
コンパイルするときに、ファイ...
-
ACCESSのEXEを作るのは可能...
-
ソースから参照しているOCXの一...
-
エラーの原因は?「この関数の...
-
VB6で、非表示モジュール(?)の...
-
VC++でexeファイルが作成できま...
-
他の.CPPファイルに定義した関...
-
C#のクラスをVB.netで使用したい!
-
VisualBasicを保存するときにで...
-
Visual Studioでプロジェクトが...
-
VB6.0の別名保存について
-
VB.NETでActiveX(OCXファイル)作成
-
Visual Stadio2008 Releaseビル...
-
「マージする」とは?
-
srand48? drand48?
-
VC++(VS)でコンソールアプリ(...
-
プリコンパイル?
-
Visual Studio2008でヘッダファ...
-
Wingdi.h Windows.h を開くには?
おすすめ情報