한셀은 어떻게 하죠?
강의 챕터 : [응용] 엑셀문서 값을 필드에 입력하기
질문사항 : 저희 회사에서는 엑셀을 사용하지 않고 한셀을 사용하도록 하는데 그 때는 어떻게 하나요?
답변 1
1
다행히 한셀의 API 인터페이스는 엑셀과 거의 동일합니다.

기존 엑셀 사용자들에게 익숙한 느낌을 주기 위해
의도적으로 엑셀과 유사하게 인터페이스를 만들었다는 느낌인데요.
(저는 그 점이 마음에 듭니다.)
하여튼 위 영상에서 간단히 사용한 코드는,
import win32com.client as win32
hcell = win32.gencache.EnsureDispatch("HCell.Application")
#%%
hcell.Visible = True
#%%
hcell.Cells(1,1).Value = "Hello World!"
#%%
for i in range(2, 11):
hcell.Cells(i, 1).Value = \
f"Hello {i}!"
#%%
위와 같습니다.
다만 엑셀도 "엑셀프로그램 - 워크북 - 워크시트" 계층이 있듯이
한셀에도 아래와 같이 계층을 짜서 프로그래밍하시는 걸 권장합니다.
import win32com.client as win32
hcell = win32.gencache.EnsureDispatch(
"HCell.Application"
)
#%% Visible 기본값은 False라서 실행해도 숨겨져 있습니다.
hcell.Visible = True
#%% 엑셀과 달리 한셀에서는 실행시점에 워크북 하나가 자동으로 만들어집니다.
wb = hcell.Workbooks(1)
#%% 워크시트도 하나 만들어져 있습니다.
ws = wb.Worksheets(1)
#%% 해당 워크시트의 Cells나 Range 등을 통해 입력하실 수 있습니다.
ws.Cells(1,1).Value = "Hello world!"
#%% 저장이나 닫기는 워크북 계층에서 실행하시면 됩니다.
wb.SaveAs("./hello.cell")
# 기본 저장 폴더 : home/Documents한셀의 COM API 코드나 파일구조는 엑셀과 굉장히 유사하다는 장점(?)이 있어,
기타 응용프로그램이나 판다스 등에서 불러오는 방법도 엑셀과 동일합니다.
다만 openpyxl이나 xlwings 등의 엑셀 라이브러리를 사용하셔야 한다면
라이브러리 일부를 약간 수정해야 합니다.
대부분의 단순작업은 win32com으로 충분하므로
기존의 방법을 사용해보시는 것을 추천드립니다.
도움이 되었길 바랍니다.
행복한 하루 되세요^^
섹션7과 같은 수학 수식을 백지에서 시작할 때 어떻게 만들 수 있을까요?
0
76
1
hwp 병렬 작업시 클립보드 충돌문제
0
58
1
본문을 각주로 내리는 법
1
93
1
한글 자동화 삽도 삽입!!
1
383
2
한글 표 내부 위치 찾는 코드좀 알려주세요 ㅠㅠ
1
231
2
빈 문서를 새로 열때는 팝업이 안나오는데 기존 문서를 열면 팝업이 나옵니다
1
117
2
사무실 컴퓨터ㅠ
0
96
2
글자입력 여러번 실행기
0
67
1
현재 커서 문단에 아무런 내용이 없는지 확인하기
1
102
1
특정 스타일을 찾아 이동하는 방법
1
161
2
한/글 파일 open 시 '상위 버전에서...' 메세지 안 뜨게 하는 방법?
1
1101
1
win32com 으로 hwp 문자열 검색하기 문의
1
222
2
[응용] 엑셀문서 값을 필드에 입력하기 질
1
122
1
표 병합하기 관련
0
140
0
메타태그 삽입 자동화
0
191
1
스크립트 매크로 초기화 하고 싶습니다.
1
269
2
한글 창이 여러 개 존재할 때 pyhwpx 모듈로 접근하는 방법을 알고 싶습니다.
1
268
1
표안의 특정 필드에 있는 이미지를 복사하여 한글 외부에 저장하기
1
272
2
스타일 싹 다 지우고 바탕글로 통일하는 방법 문의드립니다.
1
282
0
하위의 여러 폴더 중 특정폴더의 사진만 추출하기
1
343
2
한글 수식을 자동으로 넣는 코드를 만들었는데, 수식 사이의 간격이 계속 벌어집니다.
1
648
1
보유 특허 검색 페이지에서 검색이 되지 않습니다.
1
136
1
hwp 페이지별 분할 저장하는 코드 관련 문의
0
445
0
한글 문서에 사용된 폰트명 추출
1
642
1





