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 컨트롤에 대한 질문은 받지 않겠습니다. (공식적인 컨트롤이 아닌데다 개인적으로 더 이상 흥미가 없는 자료입니다.)
정성태

... 16  17  18  19  20  [21]  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13098정성태7/13/20226082개발 환경 구성: 647. Azure - scale-out 상태의 App Service에서 특정 인스턴스에 요청을 보내는 방법 [1]
13097정성태7/12/20225490오류 유형: 817. Golang - binary.Read: invalid type int32
13096정성태7/8/20228242.NET Framework: 2030. C# 11 - UTF-8 문자열 리터럴
13095정성태7/7/20226321Windows: 208. AD 도메인에 참여하지 않은 컴퓨터에서 Kerberos 인증을 사용하는 방법
13094정성태7/6/20226023오류 유형: 816. Golang - "short write" 오류 원인
13093정성태7/5/20226950.NET Framework: 2029. C# - HttpWebRequest로 localhost 접속 시 2초 이상 지연
13092정성태7/3/20227886.NET Framework: 2028. C# - HttpWebRequest의 POST 동작 방식파일 다운로드1
13091정성태7/3/20226704.NET Framework: 2027. C# - IPv4, IPv6를 모두 지원하는 서버 소켓 생성 방법
13090정성태6/29/20225837오류 유형: 815. PyPI에 업로드한 패키지가 반영이 안 되는 경우
13089정성태6/28/20226321개발 환경 구성: 646. HOSTS 파일 변경 시 Edge 브라우저에 반영하는 방법
13088정성태6/27/20225442개발 환경 구성: 645. "Developer Command Prompt for VS 2022" 명령행 환경의 폰트를 바꾸는 방법
13087정성태6/23/20228398스크립트: 41. 파이썬 - FastAPI / uvicorn 호스팅 환경에서 asyncio 사용하는 방법 [1]
13086정성태6/22/20227815.NET Framework: 2026. C# 11 - 문자열 보간 개선 2가지파일 다운로드1
13085정성태6/22/20227876.NET Framework: 2025. C# 11 - 원시 문자열 리터럴(raw string literals)파일 다운로드1
13084정성태6/21/20226518개발 환경 구성: 644. Windows - 파이썬 2.7을 msi 설치 없이 구성하는 방법
13083정성태6/20/20227090.NET Framework: 2024. .NET 7에 도입된 GC의 메모리 해제에 대한 segment와 region의 차이점 [2]
13082정성태6/19/20226135.NET Framework: 2023. C# - Process의 I/O 사용량을 보여주는 GetProcessIoCounters Win32 API파일 다운로드1
13081정성태6/17/20226210.NET Framework: 2022. C# - .NET 7 Preview 5 신규 기능 - System.IO.Stream ReadExactly / ReadAtLeast파일 다운로드1
13080정성태6/17/20226827개발 환경 구성: 643. Visual Studio 2022 17.2 버전에서 C# 11 또는 .NET 7.0 preview 적용
13079정성태6/17/20224569오류 유형: 814. 파이썬 - Error: The file/path provided (...) does not appear to exist
13078정성태6/16/20226588.NET Framework: 2021. WPF - UI Thread와 Render Thread파일 다운로드1
13077정성태6/15/20226921스크립트: 40. 파이썬 - PostgreSQL 환경 구성
13075정성태6/15/20225881Linux: 50. Linux - apt와 apt-get의 차이 [2]
13074정성태6/13/20226183.NET Framework: 2020. C# - NTFS 파일에 사용자 정의 속성값 추가하는 방법파일 다운로드1
13073정성태6/12/20226389Windows: 207. Windows Server 2022에 도입된 WSL 2
13072정성태6/10/20226680Linux: 49. Linux - ls 명령어로 출력되는 디렉터리 색상 변경 방법
... 16  17  18  19  20  [21]  22  23  24  25  26  27  28  29  30  ...