• 목록
  • 아래로
  • 위로
import olefile 

f = olefile.OleFileIO('파일명.hwp') # HWP 파일 열기
encoded_text = f.openstream('PrvText').read() # PrvText 스트림의 내용 꺼내기
decoded_text = encoded_text.decode('UTF-16') # 유니코드를 UTF-16으로 디코딩
print(decoded_text)

 

 

참고로 pyhwp라는 모듈도 있는데 이것도 olefile을 디펜던시로 하고 있어요 ^^

 

작성자
이니스프리 119 Lv. (0%) 1973470/115200000EXP

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 6

NoYeah
profile image
olefile 이 한컴에서 제공하는 라이브러리인가요?
comment menu
2020.10.19. 23:11

신고

"NoYeah님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → NoYeah
profile image

그렇지 않다고 알고 있네요 ^^

https://pypi.org/project/olefile/ 여기를 보시면 OLE2 파일을 위한 범용 라이브러리임을 확인할 수 있어요 :)

olefile is a Python package to parse, read and write Microsoft OLE2 files (also called Structured Storage, Compound File Binary Format or Compound Document File Format), such as Microsoft Office 97-2003 documents, vbaProject.bin in MS Office 2007+ files, Image Composer and FlashPix files, Outlook messages, StickyNotes, several Microscopy file formats, McAfee antivirus quarantine files, etc.

 

+)

참고로 이 모듈을 개발하신 분은 다음과 같습니다 ^^

https://pypi.org/user/decalage/

comment menu
2020.10.20. 21:37

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

NoYeah → 이니스프리
profile image
한글 파일포맷이라 독자적인 포맷인줄 알았는데 어느정도 한컴에서도 표준에 맞춰 개발을 하였었나보군요?
심지어 공식적으로 지원하지 않는것 같은데 말이에요.
comment menu
2020.10.23. 15:28

신고

"NoYeah님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → NoYeah
profile image

저도 직접 파싱해본 것은 아니지만 검색해보니 그런 것 같네요 ^^
https://luji.tistory.com/15

https://luji.tistory.com/18?category=727732

comment menu
2020.10.23. 20:39

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

파이리
오옷! 감사합니다
comment menu
2021.02.08. 11:49

신고

"파이리님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → 파이리
profile image
옙~ 굿밤 되세요! ^-^
comment menu
2021.02.08. 22:19

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 마스터 24.02.11.17:21 963
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4638
551 [Python] random 함수가 계속하여 동일한 결과를 출력할 때 해결방법 이니스프리 이니스프리 2일 전19:32 56
550 트래픽 절감 관련 모 커뮤니티 사이트의 회의 결과 이니스프리 이니스프리 2일 전16:51 68
549 색상선택 결정문제를 겪고 계신 분들 위한 사이트 OAUTH2 20.06.19.18:22 69
548 database 백업 및 복원을 지원하는 site입니다. 해피보이 20.06.03.20:52 77
547 [펌] Chrome will soon be less of a memory hog in Windows 10 3 이니스프리 이니스프리 20.06.24.00:12 82
546 [Python] Ubuntu에서 파이썬이 설치된 디렉토리를 간단히 확인하는 방법 2 이니스프리 이니스프리 20.08.03.22:58 88
545 [Python] SSL: CERTIFICATE_VERIFY_FAILED에 대한 대처 방법 (2) 이니스프리 이니스프리 24.05.05.21:04 93
544 [Javascript] 값을 이용하여 배열의 요소를 삭제하는 방법 이니스프리 이니스프리 21.04.13.22:10 97
543 순수 React만으로 다이내믹 태그 네이밍하기 Seia Seia 20.01.20.19:18 104
542 React 그리고 Redux 쉽게 이해하기 image Seia Seia 20.09.12.06:31 104
541 [Python] Tabulate 모듈로 작성한 테이블을 파일로 저장할 때 에러가 발생하는 경우 이니스프리 이니스프리 24.04.20.23:45 104
540 [Python] 문자열에서 파일명 또는 폴더명으로 시스템상 지원되는 글자를 제외하고 삭제하기 이니스프리 이니스프리 20.11.01.14:37 105
539 나리야 익명보드 및 내 글 알림 관련 Q&A image 이니스프리 이니스프리 21.02.14.17:30 107
538 [Python] 크롤링한 bytes를 string으로 변환 이니스프리 이니스프리 21.02.14.15:32 109
537 [KT] 오피스넷 가정 설치 관련 이니스프리 이니스프리 24.05.05.00:28 110
536 중국 배대지 휴무 이니스프리 이니스프리 20.01.14.13:01 112
535 [Python] 3개의 list를 하나의 dictionary로 변환하기 이니스프리 이니스프리 20.06.10.21:47 114
534 IPVanish의 한국서버가 4개로 확충되었습니다. image 이니스프리 이니스프리 20.01.11.11:27 116
533 헷갈리는 출생지를 가진 인물들 1 이니스프리 이니스프리 20.06.26.21:09 116
532 MS Office 제품군 명칭 변경 image 이니스프리 이니스프리 20.07.02.18:05 116