1. FAQ
  2. 엑셀(Excel)
  3. AfterEffects
  4. Premiere
  5. Photoshop
  6. ETC

이 게시판은 아별닷컴 회원만 질문을 올릴 수 있습니다. 회원에게 주어지는 특권인셈이지요. 회원이 아닌 분들은 열람만 가능합니다.

Excel에서 DLL Load

VBA 조회 수 3009 추천 수 0 2012.10.23 18:09:42

안녕하세요? 아별님

이틀내내 인터넷에 찾아보고 해도 문제를 풀지 못해 부탁 드립니다.

 

Excel에서 DLL을 실행시키기 위해 아래와 같은 아주 간단한 VC 2008로 MyDllAny.dll을 만들고 그 결과를 메세지창에 띄우려고 합니다.

그런데 계속 에러가 나서 염치 불구하고 어디가 잘못 되었는지 부탁드립니다.

이 사이트에 예제파일은 잘 작동이 되던데 제가 만든것은  DLL호출규정이 잘못되었다는 메세지가 나옵니다.

 

VB로 실행파일을 만들어 테스트하면 잘 되는데 Excel 파일에서 Load하면 안되는군요.

번거러우시겠지만 어디가 문제가 되는지 알려주시면 감사하겠습니다.

 

OS : Windows 7 64 Bit

Excel : Excel 2007 32 Bit

C Compiler : Visual C 2008 // DLL 파일 컴파일

 

VB : Visual Studio 2008 // 단지 Test용으로 실행파일 만든 용도며  실제 관련없음.

 

// C DLL 프로그램  내용

 

/* 직접 익스포트하기 */
extern "C" __declspec(dllexport) int AddInteger(int a, int b)
{
      return a+b;
}
//*/

//* 헤더 파일로 익스포트하기
#define DLLEXPORT
#include "MyDll.h"

extern "C" MYDLLTYPE int AddInteger(int a, int b)
{
     return a+b;
}
//*/

 

***** REM Excel module
#If Win64 Then
    Private Declare PtrSafe Function AddInteger Lib "D:\Test\MyDll64.dll" (ByVal a As integer, ByVal b As Integer) As IntPtr
#Else
    Public Declare Function AddInteger Lib "D:\Test\MyDllAny.dll" (ByVal A As Integer, ByVal B As Integer) As Integer
#End If

Sub ButtonClick()
    Dim A As Integer
    Dim B As Integer
    Dim Result As Integer
   
    Result = 100    
    Result = AddInteger(A, B)
    MsgBox Str(Result)    
End Sub

 

Visual Basic 부분

**** REM Visual Basic에서는 실행이 잘됩니다. 첨부파일 중 실행파일로 만든것

Public Class Form1
    REM Attribute VB_Name = "Module1"
    Declare Function AddInteger Lib "MyDllAny.dll" (ByVal A As Integer, ByVal B As Integer) As Integer

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        Dim Result As Integer
        Result = AddInteger(3, 4)
        Me.Label1.Text = "3+4=" + Str(Result)
    End Sub
End Class


댓글 '2'

[레벨:1]와룡

2012.10.24 10:51:28
*.75.253.250

문제해결

1. Windows 7 64Bit Office 2010 64 Bit

 1). function return value 및 parameter가 integer로 되어 있는데 이것을 Long으로 바꿈(Excel에서).  //

#If Win64 Then
    Private Declare PtrSafe Function AddInteger Lib "D:/Test/MyDll32.dll" (ByVal a As Long, ByVal b As Long) As Long
#Else
    Private Declare Function AddInteger Lib "D:/Test/MyDll32.dll" (ByVal a As Long, ByVal b As Long) As Long
#End If

 

2. Windows 7 64Bit Office 2007 32 Bit

 1) C에서 DLL 파일을 만들때 def 파일을 이용해서 만들것

 Ex) MyDll32.def

LIBRARY "MyDll32"

EXPORTS

AddInteger @1

 

VC, VB로 만든 실행파일과 Excel2010으로서 동일한 dll 파일을 loading하는것은 전혀 문제가 없었으나 Excel 2007에서는 문제가 발생,

따라서 dll 파일을 만들때 함수 export부분을 구 방식으로 만들어야 합니다.

profile

[레벨:30]아별

2012.10.29 15:50:14
*.104.126.21

헐.. 해보진 않았지만.. 님 좀 짱이신듯..? ㅎㅎ

처음에 언뜻 보고서.. CAS(Code Access Security)문제가 아닐까했었는데..


저도 요즘 VSTO 개발을 공부하고 있기는 한데.. 배포가 가장 어려운것 같습니다.

자동 업데이트도 안되고.. 원클릭으로 MSI가 아닌 설치파일(.exe)로 만들어서 배포하는걸 해보고 싶은데..

쉽지 않네요.. +_+;;


VSTO 강좌 게시판 하나 만들어드릴까요? ^_^;;


문서 첨부 제한 : 0Byte/ 2.00MB
파일 제한 크기 : 2.00MB (허용 확장자 : *.*)
List of Articles
번호 제목 글쓴이 날짜 조회 수sort
공지 공지 [공지] 아별닷컴의 엑셀 질문방 폐쇄합니다. 카페 질문방 이용하세요.. imagefile [레벨:30]아별 2015-04-23 60243
93 VBA 한셀안의 서식을 다르게 지정할 수 있는 방법 없을까요? file [5] [레벨:4]부루끄 2011-09-28 6452
92 VBA 병합효과 file [3] [레벨:4]고수가되고파 2012-11-22 6313
91 VBA 특정색 행 삭제 메크로 배워보고 싶습니다~ imagefile [2] [레벨:1]굿한넘 2015-01-12 6194
90 VBA 특정값이 변경될 경우 매크로실행 또는 0이 아닐경우 실행 [2] [레벨:3]jmsynn 2014-10-24 5672
89 VBA 엑셀 랜덤돌리기 질문입니다 file [2] [레벨:4]신강현 2012-12-07 5592
88 VBA 파일&폴더 ExecuteExcel4Macro로 다른 파일 열지않고 셀 데이터 가져오기 시 실패 file [레벨:1]소주보이 2014-02-28 5499
87 VBA 엑셀 내용에서 영어만 모두 제거할 수 있을까요?? [1] [레벨:1]초보배움 2015-02-20 5402
86 VBA win7 64bit / 64bit 엑셀 / 32bit DLL의 사용법이 궁금합니다. file [레벨:1]컴바치 2013-01-04 5274
85 VBA 엑셀 vba 함수 질문드릴게요. [4] [레벨:4]신강현 2013-03-04 5123
84 VBA 엑셀 메모의 배경으로 삽입한 이미지 추출하기 file [레벨:2]이런젬젬 2015-01-06 5115
83 VBA 2개의 시트를 비교하여 다른 부분을 찾아내는 프로시저 질문입니다! file [3] [레벨:6]파이스 2011-11-24 5091
82 VBA 외부 어플리케이션 실행 & 유저폼 일괄 닫기 & 리본 메뉴 사용자 추가 탭 숨기거나 보이게 하는 방법 [7] [레벨:3]엑셀대단해 2012-02-08 4962
81 VBA 수식이 입력된 셀은 자동으로 색상이 들어가게 하는 방법 [5] [레벨:4]부루끄 2011-07-15 4891
80 VBA vba로 서식정렬 [4] [레벨:2]정용규 2015-01-03 4884
79 VBA 오늘도 질문!^^있습니다. [레벨:2]정용규 2015-01-19 4679
78 VBA vba 방향키 질문입니다 [4] [레벨:4]기능인 2013-07-11 4677
77 VBA [긴급] Range 범위 "A2:A10" -> 를 변수로 받게 하는 방법.. file [3] [레벨:1]마리너 2012-07-05 4660
76 VBA 아별님 안녕하세요 file [레벨:2]북곰 2014-07-09 4630
75 VBA VBA 서적 추천좀 해주세요 [1] [레벨:1]김학래 2013-04-01 4610
74 VBA 아별님! 엑셀 질문입니다. _ 고급필터를 활용한 데이터 분리 작업(각 시트로 분리) file [3] [레벨:2]북곰 2013-04-06 4581