hwp-mcp
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 이상 필요.
도구 목록
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(의도적 제외).
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). Install: claude mcp add hwp-mcp -- npx -y hwp-mcp.
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