hwp-mcp
hwp-mcp is an MCP server that enables AI agents to read, modify, and create HWP/HWPX (Hangul Word Processor) documents. Reading is supported for both .hwp and .hwpx files; writing is exclusive to .hwpx.
Read & Extract Content
Extract full document text, tables (as Markdown), headers/footers, footnotes, and equations
List and save embedded images to disk
Metadata & Inspection
Retrieve document info: version, page count, fonts, table/image/footnote/equation counts
Get page layout (paper size, margins, columns) per section
List Hancom fields, get field values, and list BinData entries in
.hwpxarchives
Visual Rendering
Render individual pages or all pages as SVG or HTML
Convert OWPML math equation scripts to SVG
Text Editing (.hwpx only)
Find and replace text, fill
{{placeholder}}templates, set paragraph or cell text, set Hancom field values
Structural Editing (.hwpx only)
Append/delete paragraphs and table rows/columns
Merge cells horizontally or vertically
Insert, replace, or delete embedded images
Insert new OWPML tables (experimental)
Formatting (.hwpx only)
Apply character styles: color, bold, italic, underline, font size
Apply paragraph styles: alignment, indent, line spacing
Document Creation
Create brand-new
.hwpxdocuments from text and table content
Allows extracting tables from HWP and HWPX documents and converting them into Markdown format for structured data representation.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@hwp-mcpRead the content of report.hwp and extract all tables"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
hwp-mcp
Claude · Cursor · ChatGPT 등 MCP 호환 AI에서 한글 문서(.hwp / .hwpx) 를 읽고 수정하고 새로 만들 수 있게 해주는 서버입니다.
hwp-mcp은 한컴오피스 문서를 AI 에이전트가 직접 다루도록 해주는 MCP(Model Context Protocol) 서버입니다. 읽기뿐 아니라 텍스트 수정, 템플릿 채우기, 새 문서 생성까지 가능합니다.
어떤 프로젝트인가요?
이 프로젝트는 두 부분으로 나뉩니다.
🔧 rhwp가 한 일 (핵심 엔진) — Edward Kim 님의 rhwp는 닫힌 한글 포맷(HWP 5.0 binary, HWPX/OWPML)을 전부 역공학으로 풀어 Rust + WebAssembly로 구현한 오픈소스 엔진입니다. 파싱, 표·이미지·수식·머리말 추출, SVG 렌더링, 한컴 호환 Field API — 이 모든 핵심 능력은 rhwp 가 제공합니다. rhwp 가 없으면 이 프로젝트도 없습니다.
🤝
hwp-mcp가 한 일 (에이전트 어댑터) —@rhwp/core위에 얹은 얇은 MCP 서버 layer. 우리가 추가한 것은:read_hwp,fill_hwp_template,replace_hwp_text같은 에이전트 친화적 도구 시그니처 — Claude/Cursor 같은 LLM이 자연어로 호출할 수 있게본문·표·이미지·머리말·꼬리말·각주·수식을 한 번에 dump 하는 시나리오 중심 traversal walker
표 셀 병합 자동 처리, footnote/equation 자동 합본 같은 사용 편의 layer
rhwp 0.7.7 의
exportHwpx라운드트립 한계를 우회하기 위한.hwpxZIP-level mutation layer (실제 쓰기를 가능하게 하는 핵심)npm
hwp-mcp패키지 (한 줄 설치) + Node.js WASM 부트스트랩
요약: AI가 한글 문서를 진짜로 읽고 쓸 수 있게 해주는 어댑터입니다. 모든 오픈 한글 능력에 대한 감사는 rhwp 프로젝트에 보내주세요 🙏
설치
Claude Code
claude mcp add hwp-mcp -- npx -y hwp-mcpClaude Desktop / Cursor / VS Code (settings JSON)
{
"mcpServers": {
"hwp-mcp": {
"command": "npx",
"args": ["-y", "hwp-mcp"]
}
}
}Node.js 20 이상 필요.
설치 확인
claude mcp list | grep hwp-mcp
# hwp-mcp: npx -y hwp-mcp - ✓ Connected✓ Connected 가 뜨면 끝.
처음 써보기 (60초)
설치 직후 동작 확인용 가장 짧은 검증:
나: 새 hwpx 문서 만들어줘. 파일 이름은 hello.hwpx 이고 "안녕 한글" 한 줄만 들어가게.
AI: HWPX 문서 생성 완료 (created): hello.hwpx
나: hello.hwpx 읽어줘.
AI: # hello.hwpx
안녕 한글위 두 단계가 되면 읽기·쓰기 양쪽 다 동작합니다. 이제 실제 문서로:
~/Downloads/공고문.hwp 읽어줘report.hwpx 의 {{이름}}을 남대현으로, {{날짜}}를 2026-05-26으로 채워줘document.hwpx 의 첫 페이지를 SVG로 보여줘
안 되면?
증상 | 원인 / 해결 |
|
|
설치는 됐는데 | Claude Code / Cursor 세션 재시작 필요 (MCP 도구는 세션 시작 시점에 로드됨) |
| Node 20+ 인지 확인: |
|
|
Claude Desktop / Cursor 에서 안 보임 | 설정 JSON 저장 후 앱 완전 종료 + 재실행 (백그라운드 트레이도 종료) |
v0.2.0 → v0.2.1 업그레이드:
claude mcp remove hwp-mcp
claude mcp add hwp-mcp -- npx -y hwp-mcp@latest
claude mcp list | grep hwp-mcp # ✓ Connected설정 파일 방식(Claude Desktop/Cursor)이면 args 를 ["-y", "hwp-mcp@latest"] 로:
{
"mcpServers": {
"hwp-mcp": {
"command": "npx",
"args": ["-y", "hwp-mcp@latest"]
}
}
}여전히 안 되면: Issues 에 node --version, claude mcp list 출력, 실행 OS 적어서 알려주세요.
도구 목록
hwp-mcp v0.2가 노출하는 34개 MCP 도구입니다. 읽기·렌더는 .hwp/.hwpx 모두 지원, 쓰기는 .hwpx 전용입니다.
읽기 (5)
도구 |
|
| 설명 |
| ✅ | ✅ | 본문 + 표(마크다운) + 이미지 목록 한 번에 |
| ✅ | ✅ | 본문 + 머리말 + 꼬리말 + 각주 + 수식 통합 텍스트 |
| ✅ | ✅ | 표를 GitHub 마크다운으로 (셀 병합 처리) |
| ✅ | ✅ | 임베디드 이미지 목록 (mime, 바이트) |
| ✅ | ✅ | 이미지를 디스크로 추출 |
메타 / 조회 (5)
도구 |
|
| 설명 |
| ✅ | ✅ | 버전·페이지·글꼴·표/이미지/각주/수식 통계 |
| ✅ | ✅ | 섹션별 용지 크기·여백·단·헤더/푸터 마진 |
| ✅ | ✅ | 한컴 필드 목록 |
| ✅ | ✅ | 필드 값 조회 |
| – | ✅ |
|
시각 렌더 (4)
도구 |
|
| 설명 |
| ✅ | ✅ | 특정 페이지 → SVG (인라인/파일) |
| ✅ | ✅ | 전체 페이지 SVG 일괄 |
| ✅ | ✅ | 페이지 → HTML |
| – | – | OWPML 수식 script → SVG |
쓰기 — 텍스트 (5)
도구 |
| 설명 |
| ✅ | 특정 문자열 찾아 바꾸기 |
| ✅ |
|
| ✅ | N번째 문단 텍스트 통째 교체 |
| ✅ | 표 셀 (행, 열) 텍스트 직접 설정 |
| ✅ | 필드 값 설정 |
쓰기 — 구조 (9)
도구 |
| 설명 |
| ✅ | 본문 끝에 새 문단 |
| ✅ | N번째 문단 삭제 |
| ✅ | 표 마지막에 새 행 |
| ✅ | 표 행 삭제 |
| ✅ | 표 끝에 새 열 (모든 행에) |
| ✅ | 표 열 삭제 |
| ✅ | 가로 셀 병합 (colSpan) |
| ✅ | 세로 셀 병합 (rowSpan) |
| ✅ | 임베디드 이미지 교체 |
쓰기 — 서식 (2)
도구 |
| 설명 |
| ✅ | 글자 색·볼드·이탤릭·밑줄·크기 (charPr 추가) |
| ✅ | 문단 정렬·들여쓰기·줄간격 (paraPr 추가) |
쓰기 — 이미지 / 표 / 신규 (4)
도구 |
| 설명 |
| ✅ | 새 이미지 추가 (BinData + manifest + |
| ✅ | BinData/ 엔트리 삭제 |
| ⚠️ | 새 OWPML 표 삽입 (실험적 — 파일 valid, rhwp 인식 비완전) |
| ✅ | 텍스트로 새 |
컨텐츠 추출 매트릭스
컨텐츠 | 추출 | 비고 |
본문 문단 텍스트 | ✅ |
|
표 (셀 병합 포함) | ✅ |
|
임베디드 이미지 | ✅ | PNG/JPG/BMP 등 추출 |
머리말 / 꼬리말 | ✅ |
|
각주(footnote) | ✅ | 결과 끝에 |
수식(equation) | ✅ | OWPML script 형태 (예: |
페이지 SVG 렌더 | ✅ |
|
텍스트박스 본문 | ❌ | rhwp의 |
미주(endnote) | – | rhwp 자체 미지원 (footnote만) |
차트(chart) | ❌ | v0.3 이후 |
작성 매트릭스
작업 |
|
| 비고 |
텍스트 단일 치환 | ❌ | ✅ |
|
다중 자리표시자 채우기 | ❌ | ✅ |
|
문단 텍스트 통째 교체 | ❌ | ✅ |
|
표 셀 직접 수정 | ❌ | ✅ |
|
필드 값 설정 | ❌ | ✅ |
|
새 문단 추가 / 삭제 | ❌ | ✅ |
|
표 행 추가 / 삭제 | ❌ | ✅ |
|
이미지 교체 / 삭제 | ❌ | ✅ |
|
새 문서 생성 (텍스트) | – | ✅ |
|
새 문서 생성 (표) | – | ⚠️ | 텍스트 행으로 평탄화 (v0.3에서 진짜 OWPML 표) |
새 이미지 삽입 | ❌ | ✅ |
|
표 열 추가 / 삭제 | ❌ | ✅ |
|
셀 병합 (가로·세로) | ❌ | ✅ |
|
글자 서식 (색·볼드·이탤릭·밑줄·크기) | ❌ | ✅ |
|
문단 서식 (정렬·들여쓰기·줄간격) | ❌ | ✅ |
|
새 표 삽입 (진짜 OWPML) | ❌ | ⚠️ |
|
머리말/꼬리말 신규 삽입 | ❌ | ❌ | v0.3 |
차트·북마크·스타일 정의 | ❌ | ❌ | v0.3 |
.hwp바이너리 쓰기는 rhwp 0.7.7 의exportHwp라운드트립 한계로 v0.2에서 미지원. 한컴오피스에서.hwpx로 다른 이름 저장 후 쓰기 도구를 사용하시거나, v0.3 릴리스를 기다려주세요.
사용 예시
정부 한글 문서 읽기
나: /Users/me/2026년_시행계획.hwpx 읽어줘
AI: # 2026년_시행계획.hwpx
형식: .HWPX | 문단: 153개 | 표: 15개 | 이미지: 2개
Ⅰ. 추진 배경
□ (글로벌 현황) 전세계 AI 솔루션 시장 규모는 ...
### 표 9 (7행 x 4열)
| 도메인 | 입력 데이터 | 학습 내용 | 산업AI 솔루션 적용 기능 예시 |
| --- | --- | --- | --- |
| 기계 | · 센서 데이터 로그 ... | ... | ... |템플릿 채우기
나: /path/to/form.hwpx 에서 {{이름}}=남대현, {{회사}}=포텐랩 으로 채워줘
AI: 저장 완료 (saved): form_filled.hwpx
총 2건 치환 (2 replacements)
'{{이름}}' → 1건
'{{회사}}' → 1건텍스트 치환
나: /path/to/doc.hwpx 의 "산업AI" 를 "산업-AI" 로 바꿔줘
AI: '산업AI' → '산업-AI': 18건 교체 (replaced 18)
저장 (saved): doc_modified.hwpx새 .hwpx 만들기
나: employees.hwpx 에 "사원 명부" 와 "두 번째 줄" 두 줄을 가진 문서 만들어줘
AI: HWPX 문서 생성 완료 (created): employees.hwpx이미지 추출
나: /path/to/document.hwpx 에서 이미지 빼줘
AI: 이미지 2개를 추출했습니다 (extracted 2 images):
저장 위치: /path/to/document_images
- image_001.bmp
- image_002.bmp페이지를 SVG로 렌더 (시각 분석용)
나: /path/to/document.hwpx 의 첫 페이지를 SVG로 보여줘
AI: <svg xmlns="..." width="793" height="1122" viewBox="...">
<defs>...</defs>
...
</svg>또는 디스크로 저장:
나: /path/to/document.hwpx 모든 페이지 SVG로 저장해줘
AI: 9/9 페이지 SVG 저장 (rendered 9/9 pages):
저장 위치: /path/to/document_pages
- page_001.svg
- page_002.svg ...한계
hwp-mcp v0.2의 알려진 제약 사항입니다.
.hwp쓰기 미지원 — 읽기는.hwp/.hwpx모두 됩니다. 쓰기는.hwpx만..hwp입력에 대해 쓰기 도구를 호출하면 명확한 에러 메시지를 돌려줍니다. 한컴오피스에서.hwpx로 다른 이름 저장 후 사용하시거나, v0.3 릴리스를 기다려주세요.크로스 포맷 저장 거부 —
.hwpx입력은.hwpx로만 저장됩니다.머리말/꼬리말/각주 추출 가능, 텍스트박스/미주/수식은 v0.3 —
read_hwp_text결과에 머리말은--- headers ---, 꼬리말은--- footers ---, 각주는--- footnotes ---블록으로 표시됩니다. 텍스트박스 본문, 미주, 수식 추출은 v0.3 예정.검색어가 두 텍스트 노드에 걸치면 매칭 안 됨 — 예: 한
<hp:t>가 "산업"으로 끝나고 다음이 "AI"로 시작하면 "산업AI"는 매칭 X. 한컴 hwpctl과 동일한 한계입니다.create_hwpx_document의 표는 v0.2에서 텍스트 행으로 평탄화 — 진짜 OWPML 표는 v0.3에서.
어떻게 동작하나요?
읽기:
@rhwp/core(rhwp의 Rust+WASM 파서) 가 섹션·문단·표(병합 셀 포함)·이미지를 traverse 합니다.쓰기 (.hwpx): ZIP 아카이브 안의
Contents/section*.xml을 직접 파싱해서<hp:t>텍스트 노드를 search/replace 한 뒤 다시 패키징합니다 (mimetype은 spec대로 stored). rhwp의exportHwpx()라운드트립 이슈를 우회하기 위한 layer입니다.새 문서: rhwp의
createBlankDocument+insertText로 작성한 뒤exportHwpx로 저장합니다 (텍스트 라운드트립이 안정).
크레딧
rhwp (@edwardkim) — 핵심 파서·렌더러·Field API. 닫힌 한글 포맷을 오픈한 그 모든 작업이 이 프로젝트의 토대입니다. 가능하시다면 그 프로젝트도 함께 응원해 주세요: https://github.com/edwardkim/rhwp
hwp-mcp — rhwp 위에 AI 에이전트가 자연어로 호출할 수 있게 도구화한 얇은 MCP 어댑터. 핵심 능력은 모두 rhwp 의 것이고, 우리는 그것을 LLM 에 연결한 wiring 입니다.
커버리지
영역 | 커버 |
읽기/추출 | ~90% |
렌더링 | ~85% (SVG · HTML · 수식 SVG · Canvas는 브라우저용이라 제외) |
쓰기 — 텍스트 | ~95% |
쓰기 — 구조 | ~90% (행·열·병합·이미지 4종) |
쓰기 — 서식 | ~70% (글자 + 문단) |
메타 / 필드 | ~85% |
전체 가중 | ~85% |
남은 v0.3 큰 항목: .hwp 바이너리 쓰기, 차트, 스타일 정의·적용, 텍스트박스 본문 추출, hwpctl 30 Actions(의도적 제외).
릴리스 / 이슈
버그 신고 · 기능 제안: https://github.com/treesoop/hwp-mcp/issues
이슈 올릴 때는 node --version, OS, MCP 클라이언트(Claude Code / Desktop / Cursor / …), 그리고 가능하면 재현되는 .hwpx 샘플을 첨부해주세요.
English
hwp-mcp is an MCP server for reading and writing Korean Hangul (.hwp / .hwpx) documents from Claude / Cursor / ChatGPT and any MCP-compatible client. Read works for both formats; write currently supports .hwpx (find/replace, template fill, create new doc) — .hwp write is planned for v0.3. Built on top of rhwp (Rust + WebAssembly HWP engine by Edward Kim, MIT).
claude mcp add hwp-mcp -- npx -y hwp-mcp
claude mcp list | grep hwp-mcp # ✓ ConnectedNot seeing ✓ Connected? Upgrade to v0.2.1+ (npx -y hwp-mcp@latest) — v0.2.0 had a bin-symlink bug that made the server exit silently. Tools not appearing in your AI client? Restart the session; MCP tools load at startup.
License
MIT.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/treesoop/hwp-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server