Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 3개 있습니다.)
.NET Framework: 287. Excel Sheet를 WinForm에서 사용하는 방법
; https://www.sysnet.pe.kr/2/0/1208

.NET Framework: 453. C# - 오피스 파워포인트(Powerpoint) 파일을 WinForm에서 보는 방법
; https://www.sysnet.pe.kr/2/0/1728

.NET Framework: 853. Excel Sheet를 WinForm에서 사용하는 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/12002




Excel Sheet를 WinForm에서 사용하는 방법 - 두 번째 이야기

예전에 쓴,

Excel Sheet를 WinForm에서 사용하는 방법
; https://www.sysnet.pe.kr/2/0/1208

dsoframer.ocx가 아직도 잘 동작하는군요. ^^ 그래서 오래간만에 해당 프로젝트를 Visual Studio 2019로 마이그레이션 해봤습니다. 우선, C++ 프로젝트는 빌드하면 다음과 같은 식의 매크로 사용 오류가 발생합니다.

C3688 invalid literal suffix 'DSOFRAMERCTL_CLSIDSTR'; literal operator or literal operator template 'operator ""DSOFRAMERCTL_CLSIDSTR' not found

문제가 된 소스 코드를,

hr = RegRecursiveDeleteKey(HKEY_CLASSES_ROOT, "CLSID\\"DSOFRAMERCTL_CLSIDSTR);

매크로와 큰따옴표 간의 공백만 추가하는 것으로 바꾸면 해결됩니다.

hr = RegRecursiveDeleteKey(HKEY_CLASSES_ROOT, "CLSID\\" DSOFRAMERCTL_CLSIDSTR);

이 외에는 컴파일 오류는 발생하지 않으며, 링크 단계에서 다음의 오류가 발생합니다.

Error LNK2026 module unsafe for SAFESEH image.

이건 Q&A에 따라 "Linker / Advanced / Image Has Safe Exception Handlers" 옵션 값을 꺼주면(/SAFESEH:NO) 됩니다.

그 외에 개발자 PC에 설치한 Office 버전에 따라 #import 오류가 발생하는데 이 부분은 다음과 같은 식의 매크로를 정의하는 것으로 일단 우회해서 해결했습니다.

// 아래의 경로는 개발자의 환경에 맞게 수정해야 합니다.

#if OFFICEVER == 16
#import "C:\Program Files (x86)\Microsoft Office\root\VFS\ProgramFilesCommonX86\Microsoft Shared\OFFICE16\mso.dll" rename("ColorFormat", "ColorFormatEx"),rename_namespace("Office")
#import "C:\Program Files (x86)\Microsoft Office\root\VFS\ProgramFilesCommonX86\Microsoft Shared\VBA\VBA6\VBE6EXT.olb" rename_namespace("VBE6")
#import "C:\Program Files (x86)\Microsoft Office\root\Office16\MSWORD.olb" rename("ExitWindows","ExitWindowsEx"),rename_namespace("MSWord")
#import "C:\Program Files (x86)\Microsoft Office\root\Office16\EXCEL.EXE" rename("RGB","RGBEx"),rename("DialogBox","DialogBoxEx"),rename_namespace("MSExcel")
#import "C:\Program Files (x86)\Microsoft Office\root\Office16\MSPPT.OLB" named_guids,rename_namespace("MSPPT")

#else
    // ...[생략]...
#endif

변경한 소스 코드는 다음의 github에 올려 두었습니다.

DotNetSamples/Cpp/dsoframer_v2.2.1.2
; https://github.com/stjeong/DotNetSamples/tree/master/Cpp/dsoframer_v2.2.1.2

하는 김에, 예제 코드도 새롭게 reg-free를 적용해,

Registry 등록 과정 없이 COM 개체 사용 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/1167

ocx를 regsvr32.exe로 등록 없이 사용할 수 있도록 변경했습니다.

DotNetSamples/WinForms/EmbedExcelSample
; https://github.com/stjeong/DotNetSamples/tree/master/WinForms/EmbedExcelSample




참고로, dsoframer.ocx가 보여주는 Excel 화면을 프로그래밍으로 제어하고 싶을 수 있는데요. dsoframer 컨트롤에 보면 SetFieldValue 같은 메서드를 제공하고 있긴 하지만 소스 코드를 보면 그것은 Cell과는 전혀 무관한 동작을 수행하는 것을 볼 수 있습니다. 그럼 어떻게 해야 할까요?

간단합니다. dsoframer 컨트롤이 제공하는 ActiveDocument를 dynamic 변수로 받아 VBA 스크립트에서 사용하던 식으로 접근하면 됩니다. 예를 들어, 다음의 소스 코드는 A1, A2 셀에 대해 "test"라는 문자열을 설정합니다.

private void Button1_Click(object sender, EventArgs e)
{
    dynamic doc = this.axFramerControl1.ActiveDocument;
    doc.ActiveSheet.Range("A1:A2").Cells.value = "test";
}




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/17/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2020-08-31 01시35분
[박세준] 글쓴이님 혹시 마지막에 문자열을 입력을 계속해서 밑으로 써내려갈수있는 방법이 있을까요?
A1:A2에 작성후 재입력시 B1:B2에 작성이 하고싶습니다
[guest]
2020-08-31 02시02분
@박세준 그런 경우라면 그냥 for 루프를 써서 cell의 위치를 직접 지정하면 될 텐데요.
정성태
2020-09-01 03시41분
[박세준] 답글 감사합니다!
한가지만더 조언을 구하고싶은데 엑셀시트를 오픈한상태로 이벤트를이용해 행을 삽입할수있는 방법이 있을까요..?
[guest]
2020-09-01 11시54분
이벤트를 이용한다는 것이 오픈된 엑셀 시트의 특정 이벤트를 구독하고 싶다는 건가요? 어쨌든, 예제 코드를 좀 더 추가했으니 확인해 보세요.

DotNetSamples/WinForms/EmbedExcelSample/Form1.cs
; https://github.com/stjeong/DotNetSamples/blob/master/WinForms/EmbedExcelSample/Form1.cs
정성태
2020-09-01 11시56분
* 이후, 더 이상 dsoFramer 컨트롤에 대한 질문은 받지 않겠습니다. (공식적인 컨트롤이 아닌데다 개인적으로 더 이상 흥미가 없는 자료입니다.)
정성태

... 136  137  138  139  140  141  142  143  144  145  146  [147]  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1378정성태11/22/201231595Java: 14. 안드로이드 - Hello World 실습 [7]
1377정성태11/19/201224988.NET Framework: 344. 닷넷 프로파일러 - ICorProfilerInfo::GetILFunctionBody 함수 버그
1376정성태11/15/201230227디버깅 기술: 51. 닷넷 응용 프로그램에서 특정 예외가 발생했을 때 풀 덤프 받는 방법 [6]
1375정성태11/15/201225987디버깅 기술: 50. windbg의 mscordacwks DLL 로드 문제 - 두 번째 이야기
1374정성태11/13/201224054개발 환경 구성: 175. Visual Studio의 "Extension Manager"에서 설치된 구성 요소들의 제거 버튼이 비활성화되었다면!
1373정성태11/13/201224592.NET Framework: 343. VB.NET 어셈블리의 .NET Reflector 소스 코드를 분석할 때 알아두면 좋은 사항
1372정성태11/1/2012119444Windows: 67. 64비트 윈도우에서 Internet Explorer 10이 항상 64비트로만 실행된다면? [57]
1371정성태10/31/201227066.NET Framework: 342. Python의 zip과 with 문 context를 C#과 비교하면. [3]파일 다운로드1
1370정성태10/31/201222346VS.NET IDE: 75. Visual Studio - "Active Solution Platform" 변경을 툴바에서 하는 방법
1369정성태10/31/201235693개발 환경 구성: 174. 윈도우에서 Mono 개발 환경 구성 [4]
1368정성태10/31/201226978개발 환경 구성: 173. Windows Phone SDK 8.0 설치
1367정성태10/30/201234737개발 환경 구성: 172. IIS 7.5부터 지원되는 웹 사이트 자동 시작 모드 [1]
1366정성태10/24/201226055개발 환경 구성: 171. GTK+를 윈도우 환경에 수작업 설치
1365정성태10/24/201224920개발 환경 구성: 170. 우분투 데스크톱 Active Directory 가입하기 [2]
1364정성태10/19/201221323Windows: 66. Hyper-V 2012에서 별도의 네트워크 카드를 이용한 Live Migration
1363정성태10/16/201228763개발 환경 구성: 169. Objective-C의 대안 - Xamarin의 Mono를 이용한 C# iOS 개발 환경 [2]
1362정성태10/16/201229088개발 환경 구성: 168. 우분투 서버 Active Directory 가입하기
1361정성태10/12/201222495.NET Framework: 341. .NET COM+ 를 Managed/Native 클라이언트에서 각각 호출했을 때의 콜 스택 비교 [4]파일 다운로드1
1360정성태10/9/201226856.NET Framework: 340. Windows Server 2012 - .NET Framework 1.x 미지원
1359정성태10/9/201263190Windows: 65. 윈도우 8 - Internet Explorer 10을 32비트 또는 64비트로 통합 [5]
1358정성태9/27/201226322.NET Framework: 339. .NET Profiler 주의 사항 - 하나의 exe 프로세스 내에 다중 .NET 런타임 사용
1357정성태9/27/201223427Windows: 64. Hyper-V - Windows XP의 Live Migration 오류
1356정성태9/26/201229530Windows: 63. 윈도우 서버 2012 - Hyper-V의 새로운 기능 Live Migration [6]
1355정성태9/21/201227526Team Foundation Server: 49. TFS 2012 Express의 필수 보완 작업: 데이터베이스 백업 [1]
1354정성태9/19/201224336.NET Framework: 338. .NET CLR GC 시간 측정하는 방법파일 다운로드1
1353정성태9/17/201225664.NET Framework: 337. Python의 생성기와 코루틴을 C#으로 표현하면. [2]파일 다운로드1
... 136  137  138  139  140  141  142  143  144  145  146  [147]  148  149  150  ...