HWPX MCP Server

HWPX MCP Server

Enables AI models to read, create, and edit Korean HWPX documents with advanced support for tables, paragraphs, styles, and images. It features enhanced stability through atomic file writing and smart layout recalculation to prevent document corruption.

Category
访问服务器

README

HWPX MCP Server - Enhanced Edition

GitHub Fork

🚀 Original 프로젝트를 Fork하여 안정성과 기능을 대폭 개선한 버전입니다.

AI 도구(Claude 등)와 연동하여 한글(HWPX) 문서를 자동으로 편집할 수 있는 MCP(Model Context Protocol) 서버입니다.


🌍 Cross-Platform Support

모든 운영체제에서 작동합니다!

OS MCP 서버 HWPX 편집 결과물 확인
✅ Windows 한컴오피스
✅ macOS 한컴오피스 Mac
✅ Linux 한컴오피스 Linux / LibreOffice*

왜 가능한가요? HWPX 파일은 ZIP + XML 구조입니다. 한글 프로그램 없이도 Node.js만으로 완벽하게 읽고 쓸 수 있습니다.

*LibreOffice는 HWPX를 제한적으로 지원합니다. 완벽한 호환을 위해 한컴오피스 사용을 권장합니다.


✨ Enhanced Features (개선된 기능)

원본 프로젝트 대비 다음과 같은 핵심 문제들을 해결했습니다:

🔧 Critical Bug Fixes

문제 원본 상태 개선 후
테이블 저장 실패 셀 수정 후 저장해도 변경사항 사라짐 ✅ 완벽하게 저장됨
텍스트 겹침 현상 저장 후 한글에서 열면 글자가 겹쳐 표시 ✅ 정상 표시
파일 손상 저장 시 가끔 파일이 손상됨 ✅ 원자적 쓰기로 100% 안전
다중 셀 손상 같은 행에 여러 셀 수정 시 XML 손상 ✅ 인덱스 관리로 안전
자간/줄간격 손실 저장 후 스타일 정보 유실 ✅ 모든 스타일 보존

🛠 Technical Improvements

  1. Atomic File Writing (원자적 파일 쓰기)

    • 임시 파일 → ZIP 검증 → 원자적 이동
    • 저장 중 오류 발생해도 원본 파일 보호
  2. Smart Lineseg Reset (스마트 줄 레이아웃 초기화)

    • 텍스트 수정 시 lineseg 자동 초기화
    • 한글 프로그램이 열 때 자동으로 줄바꿈 재계산
    • 텍스트 겹침 현상 완전 해결
  3. Depth-based XML Parsing (깊이 기반 XML 파싱)

    • 기존 lazy regex의 중첩 구조 오인식 문제 해결
    • 복잡한 테이블(중첩 테이블, subList 등) 완벽 지원
  4. Complete Style Preservation (스타일 완전 보존)

    • charPr, spacing 등 원본 스타일 100% 유지
    • 불완전한 직렬화 로직 제거로 데이터 무결성 보장
  5. Safe Multi-Cell Updates (안전한 다중 셀 업데이트)

    • 같은 행(row)의 여러 셀을 동시에 수정해도 안전
    • 행별 그룹화 + 역순 처리로 인덱스 손상 방지

📦 Installation

1. MCP 서버 설치

git clone https://github.com/Dayoooun/hwpx-mcp.git
cd hwpx-mcp/mcp-server
npm install
npm run build

2. MCP 클라이언트 설정

아래에서 사용하는 클라이언트를 선택하세요.


🖥️ Claude Desktop

설정 파일 위치:

OS 경로
Windows %APPDATA%\Claude\claude_desktop_config.json
macOS ~/Library/Application Support/Claude/claude_desktop_config.json
Linux ~/.config/Claude/claude_desktop_config.json

설정 내용:

{
  "mcpServers": {
    "hwpx-mcp": {
      "command": "node",
      "args": ["C:/path/to/hwpx-mcp/mcp-server/dist/index.js"]
    }
  }
}

⚠️ Windows에서는 경로에 \\ 또는 / 사용 (예: C:/Users/username/hwpx-mcp/...)


💻 Claude Code (CLI)

방법 1: 프로젝트별 설정 (.mcp.json 파일을 프로젝트 루트에 생성)

{
  "mcpServers": {
    "hwpx-mcp": {
      "command": "node",
      "args": ["/path/to/hwpx-mcp/mcp-server/dist/index.js"]
    }
  }
}

방법 2: 전역 설정 (~/.claude/settings.json)

{
  "mcpServers": {
    "hwpx-mcp": {
      "command": "node",
      "args": ["/path/to/hwpx-mcp/mcp-server/dist/index.js"]
    }
  }
}

방법 3: CLI 명령어로 추가

claude mcp add hwpx-mcp node /path/to/hwpx-mcp/mcp-server/dist/index.js

🔷 Cursor

설정 파일: ~/.cursor/mcp.json (없으면 생성)

{
  "mcpServers": {
    "hwpx-mcp": {
      "command": "node",
      "args": ["/path/to/hwpx-mcp/mcp-server/dist/index.js"]
    }
  }
}

또는 Cursor Settings > MCP 에서 직접 추가 가능


🆚 VS Code (MCP 확장 사용 시)

설정 파일: .vscode/mcp.json (프로젝트 폴더 내)

{
  "servers": {
    "hwpx-mcp": {
      "command": "node",
      "args": ["${workspaceFolder}/../hwpx-mcp/mcp-server/dist/index.js"]
    }
  }
}

${workspaceFolder} 변수를 활용하면 상대 경로 지정 가능


🛠️ 기타 MCP 클라이언트

일반적인 MCP 설정 형식:

{
  "mcpServers": {
    "hwpx-mcp": {
      "command": "node",
      "args": ["/absolute/path/to/hwpx-mcp/mcp-server/dist/index.js"]
    }
  }
}

경로 예시:

OS 경로 예시
Windows C:/Users/username/hwpx-mcp/mcp-server/dist/index.js
macOS /Users/username/hwpx-mcp/mcp-server/dist/index.js
Linux /home/username/hwpx-mcp/mcp-server/dist/index.js

3. 설치 확인

클라이언트 재시작 후 MCP 도구 목록에서 hwpx-mcp 서버와 77개 도구가 표시되면 성공!


🔌 MCP Tools (77개)

📁 문서 관리 (Document Management) - 5개

Tool 설명 주요 파라미터
create_document 새 빈 HWPX 문서 생성 title?, creator?
open_document HWPX 문서 열기 file_path
close_document 열린 문서 닫기 doc_id
save_document 문서 저장 (백업/무결성 검증 지원) doc_id, output_path?, create_backup?, verify_integrity?
list_open_documents 현재 열린 문서 목록 조회 -

📄 문서 정보 (Document Info) - 5개

Tool 설명 주요 파라미터
get_document_text 문서 전체 텍스트 추출 doc_id
get_document_structure 문서 구조 조회 (섹션/단락/테이블/이미지 수) doc_id
get_document_metadata 메타데이터 조회 (제목, 저자, 날짜 등) doc_id
set_document_metadata 메타데이터 수정 doc_id, title?, creator?, subject?, description?
get_word_count 글자수/단어수 통계 doc_id

📝 단락 (Paragraphs) - 8개

Tool 설명 주요 파라미터
get_paragraphs 단락 목록 조회 (텍스트/스타일 포함) doc_id, section_index?
get_paragraph 특정 단락 상세 정보 doc_id, section_index, paragraph_index
insert_paragraph 새 단락 삽입 doc_id, section_index, after_index, text
delete_paragraph 단락 삭제 doc_id, section_index, paragraph_index
update_paragraph_text 단락 텍스트 내용 수정 doc_id, section_index, paragraph_index, text, run_index?
append_text_to_paragraph 기존 단락에 텍스트 추가 doc_id, section_index, paragraph_index, text
copy_paragraph 단락을 다른 위치로 복사 doc_id, source_section, source_paragraph, target_section, target_after
move_paragraph 단락을 다른 위치로 이동 doc_id, source_section, source_paragraph, target_section, target_after

🎨 텍스트 스타일 (Text Styling) - 4개

Tool 설명 주요 파라미터
get_text_style 글자 서식 조회 (폰트/크기/색상 등) doc_id, section_index, paragraph_index, run_index?
set_text_style 글자 서식 설정 doc_id, section_index, paragraph_index, bold?, italic?, underline?, strikethrough?, font_name?, font_size?, font_color?, background_color?
get_paragraph_style 문단 서식 조회 (정렬/줄간격/여백 등) doc_id, section_index, paragraph_index
set_paragraph_style 문단 서식 설정 doc_id, section_index, paragraph_index, align?, line_spacing?, margin_*?, first_line_indent?

🔍 검색/치환 (Search & Replace) - 4개

Tool 설명 주요 파라미터
search_text 문서 내 텍스트 검색 (정규식 지원, 테이블 셀 포함) doc_id, query, case_sensitive?, regex?, include_tables?
replace_text 텍스트 찾아 바꾸기 doc_id, old_text, new_text, case_sensitive?, regex?, replace_all?
replace_text_in_cell 특정 테이블 셀 내 텍스트 치환 doc_id, section_index, table_index, row, col, old_text, new_text
batch_replace 여러 텍스트 일괄 치환 doc_id, replacements[] (old_text, new_text 쌍 배열)

📊 테이블 (Tables) - 12개

Tool 설명 주요 파라미터
get_tables 문서 내 모든 테이블 목록 doc_id
get_table 특정 테이블 전체 데이터 조회 doc_id, section_index, table_index
get_table_cell 특정 셀 내용 조회 doc_id, section_index, table_index, row, col
update_table_cell 셀 내용 수정 (스타일 보존) doc_id, section_index, table_index, row, col, text, char_shape_id?
set_cell_properties 셀 속성 설정 (크기/배경색/정렬) doc_id, section_index, table_index, row, col, width?, height?, background_color?, vertical_align?
insert_table 새 테이블 삽입 doc_id, section_index, after_index, rows, cols, width?
insert_table_row 테이블에 행 삽입 doc_id, section_index, table_index, after_row, cell_texts?
delete_table_row 테이블에서 행 삭제 doc_id, section_index, table_index, row_index
insert_table_column 테이블에 열 삽입 doc_id, section_index, table_index, after_col
delete_table_column 테이블에서 열 삭제 doc_id, section_index, table_index, col_index
insert_nested_table 셀 안에 중첩 테이블 삽입 (표 안에 표) doc_id, section_index, parent_table_index, row, col, nested_rows, nested_cols, data?
get_table_as_csv 테이블을 CSV 형식으로 추출 doc_id, section_index, table_index, delimiter?

📐 페이지 설정 (Page Settings) - 2개

Tool 설명 주요 파라미터
get_page_settings 페이지 설정 조회 (용지 크기/여백) doc_id, section_index?
set_page_settings 페이지 설정 변경 doc_id, section_index?, width?, height?, margin_*?, orientation?

🖼️ 이미지 (Images) - 5개

Tool 설명 주요 파라미터
get_images 문서 내 모든 이미지 목록 doc_id
insert_image 이미지 파일 삽입 (BinData 자동 등록) doc_id, section_index, after_index, image_path, width?, height?
update_image_size 기존 이미지 크기 변경 doc_id, section_index, image_index, width, height
delete_image 이미지 삭제 doc_id, section_index, image_index
render_mermaid Mermaid 다이어그램을 이미지로 삽입 doc_id, mermaid_code, after_index, section_index?, width?, height?, theme?, background_color?

✏️ 도형 (Shapes) - 3개

Tool 설명 주요 파라미터
insert_line 선 도형 삽입 doc_id, section_index, after_index, x1, y1, x2, y2, stroke_color?, stroke_width?
insert_rect 사각형 도형 삽입 doc_id, section_index, after_index, x, y, width, height, fill_color?, stroke_color?
insert_ellipse 타원 도형 삽입 doc_id, section_index, after_index, cx, cy, rx, ry, fill_color?, stroke_color?

📑 머리글/바닥글 (Header/Footer) - 4개

Tool 설명 주요 파라미터
get_header 머리글 내용 조회 doc_id, section_index?
set_header 머리글 설정 doc_id, text, section_index?, apply_page_type? (both/even/odd)
get_footer 바닥글 내용 조회 doc_id, section_index?
set_footer 바닥글 설정 doc_id, text, section_index?, apply_page_type? (both/even/odd)

📌 각주/미주 (Footnotes/Endnotes) - 4개

Tool 설명 주요 파라미터
get_footnotes 문서 내 모든 각주 목록 doc_id
insert_footnote 특정 위치에 각주 삽입 doc_id, section_index, paragraph_index, text
get_endnotes 문서 내 모든 미주 목록 doc_id
insert_endnote 특정 위치에 미주 삽입 doc_id, section_index, paragraph_index, text

🔗 북마크/하이퍼링크 (Bookmarks/Hyperlinks) - 4개

Tool 설명 주요 파라미터
get_bookmarks 문서 내 모든 북마크 목록 doc_id
insert_bookmark 특정 위치에 북마크 삽입 doc_id, section_index, paragraph_index, name
get_hyperlinks 문서 내 모든 하이퍼링크 목록 doc_id
insert_hyperlink 하이퍼링크 삽입 doc_id, section_index, paragraph_index, url, text

➗ 수식 (Equations) - 2개

Tool 설명 주요 파라미터
get_equations 문서 내 모든 수식 목록 doc_id
insert_equation 수식 삽입 (HWP 수식 스크립트 형식) doc_id, section_index, after_index, script

💬 메모 (Memos/Comments) - 3개

Tool 설명 주요 파라미터
get_memos 문서 내 모든 메모/주석 목록 doc_id
insert_memo 메모/주석 삽입 doc_id, section_index, paragraph_index, content, author?
delete_memo 메모/주석 삭제 doc_id, memo_id

📚 섹션 (Sections) - 5개

Tool 설명 주요 파라미터
get_sections 문서 내 모든 섹션 목록 doc_id
insert_section 새 섹션 삽입 doc_id, after_index
delete_section 섹션 삭제 doc_id, section_index
get_section_xml 섹션 Raw XML 조회 (AI 문서 조작용) doc_id, section_index?
set_section_xml 섹션 Raw XML 교체 (HWPML 형식 필수) doc_id, xml, section_index?, validate?

🎭 스타일 정의 (Style Definitions) - 4개

Tool 설명 주요 파라미터
get_styles 문서에 정의된 스타일 목록 doc_id
get_char_shapes 글자 모양(CharShape) 정의 목록 doc_id
get_para_shapes 문단 모양(ParaShape) 정의 목록 doc_id
apply_style 단락에 스타일 적용 doc_id, section_index, paragraph_index, style_id

📰 단 설정 (Column Layout) - 2개

Tool 설명 주요 파라미터
get_column_def 단(Column) 설정 조회 doc_id, section_index?
set_column_def 단 설정 변경 (다단 편집) doc_id, count, section_index?, type?, same_size?, gap?

📤 내보내기 (Export) - 2개

Tool 설명 주요 파라미터
export_to_text 문서를 텍스트 파일로 내보내기 doc_id, output_path
export_to_html 문서를 HTML 파일로 내보내기 doc_id, output_path

↩️ 실행 취소 (Undo/Redo) - 2개

Tool 설명 주요 파라미터
undo 마지막 변경 실행 취소 doc_id
redo 실행 취소한 변경 다시 실행 doc_id

사용 예시

// 문서 열기
await mcp.open_document({ file_path: "report.hwpx" })

// 테이블 셀 수정
await mcp.update_table_cell({
  doc_id: "...",
  section_index: 0,
  table_index: 0,
  row: 0,
  col: 1,
  text: "수정된 내용"
})

// 중첩 테이블 삽입 (표 안에 표)
await mcp.insert_nested_table({
  doc_id: "...",
  section_index: 0,
  parent_table_index: 0,
  row: 1,
  col: 2,
  nested_rows: 2,
  nested_cols: 2,
  data: [["A1", "A2"], ["B1", "B2"]]
})

// Mermaid 다이어그램 삽입
await mcp.render_mermaid({
  doc_id: "...",
  mermaid_code: "graph TD; A-->B; B-->C;",
  after_index: 0,
  theme: "default"
})

// 저장
await mcp.save_document({ doc_id: "..." })

테이블 셀 검색/치환 워크플로우

동일한 텍스트가 여러 곳에 있을 때 특정 위치만 수정하는 방법:

// 1. 테이블 포함 검색으로 위치 파악
const results = await mcp.search_text({
  doc_id: "...",
  query: "수정대상",
  include_tables: true  // 테이블 셀 포함
})
// 결과: [{ text: "수정대상", location: { type: "table", tableIndex: 2, row: 3, col: 1 } }, ...]

// 2. 원하는 위치의 셀만 정밀 치환
await mcp.replace_text_in_cell({
  doc_id: "...",
  section_index: 0,
  table_index: 2,  // 검색 결과에서 확인한 위치
  row: 3,
  col: 1,
  old_text: "수정대상",
  new_text: "새로운내용"
})

📋 Supported Format

포맷 확장자 읽기 쓰기
HWPX .hwpx
HWP .hwp

Note: HWP(바이너리) 파일은 지원하지 않습니다. 한컴오피스에서 HWPX로 변환 후 사용하세요.


📝 Release Notes

v0.4.0 (Enhanced Search & Diagram Support)

  • 🆕 New Feature: search_textinclude_tables 옵션 추가 - 테이블 셀 내 텍스트도 검색
  • 🆕 New Feature: replace_text_in_cell - 특정 테이블 셀 내 텍스트만 정밀 치환
  • 🆕 New Feature: render_mermaid - Mermaid 다이어그램을 이미지로 문서에 삽입
    • Flowchart, Sequence, Class Diagram 등 모든 Mermaid 문법 지원
    • 테마 선택 가능 (default, dark, forest, neutral)
  • 🆕 New Feature: get_section_xml / set_section_xml - 섹션 Raw XML 직접 조작
    • AI 기반 고급 문서 편집 시나리오 지원
  • 🔧 Improvement: insert_image 완전 개선
    • BinData 폴더에 이미지 자동 저장
    • content.hpf 매니페스트 자동 등록
    • 파일 손상 없이 이미지 삽입 보장

v0.3.0 (Nested Table Support)

  • 🆕 New Feature: insert_nested_table - 테이블 셀 안에 중첩 테이블 삽입 기능
    • 부모 테이블의 특정 셀에 새 테이블을 삽입
    • 초기 데이터 지정 가능 (2D 배열)
    • HWPX 표준 구조(treatAsChar, hp:subList) 완벽 준수
  • 🔧 Improvement: charSpacing 파싱 개선 (속성 순서 무관하게 처리)

v0.2.1 (Critical Fix)

  • 🔥 Critical Fix: 같은 행에 여러 셀 동시 수정 시 파일 손상 문제 완전 해결
    • 행(row)별 업데이트 그룹화로 인덱스 불일치 방지
    • 역순(descending) 처리로 안전한 XML 수정 보장

v0.2.0 (Enhanced Edition)

  • 🔥 Major Fix: 텍스트 수정 시 lineseg 자동 초기화로 겹침 현상 완전 해결
  • 🔧 Bug Fix: 중첩 테이블 구조에서 XML 요소 경계 오인식 문제 수정
  • 🛡️ Stability: 원자적 파일 쓰기로 파일 손상 방지
  • 📦 Preservation: 원본 charPr/spacing 스타일 완전 보존

v0.1.0 (Original)

  • 최초 릴리스 (mjyoo2/hwp-extension)

🙏 Credits


📄 License

MIT


🤝 Contributing

버그 리포트 및 기능 요청: GitHub Issues

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选