Skip to main content

Matplotlib 한글 폰트 자동 설정 라이브러리

Project description

helper-plot-hangul

Matplotlib 한글 폰트 자동 설정 라이브러리

개요

helper-plot-hangul은 Matplotlib에서 한글을 자동으로 표시할 수 있도록 폰트를 설정해주는 라이브러리입니다. 번거로운 폰트 설정 없이 간단하게 한글 그래프를 그릴 수 있습니다.

특징

  • 자동 폰트 설정: NanumGothic 폰트를 자동으로 로드하고 설정
  • 완전한 matplotlib 리셋: 폰트 캐시를 포함한 완전한 초기화
  • 스타일 호환: matplotlib 스타일 적용 후에도 한글 폰트 자동 유지
  • Jupyter/Colab 최적화: IPython 환경에서 완벽하게 작동
  • NumPy 2.0+ 호환: 최신 NumPy와 호환되는 안전한 폰트 설정
  • 내장 폰트: NanumGothic, NanumBarunGothic 폰트 포함 (별도 설치 불필요)

설치

pip install helper-plot-hangul

# 테스트 서버
pip install --index-url https://test.pypi.org/simple/ helper-plot-hangul

사용법

기본 사용법

import helper_plot_hangul  # import 시 한글 폰트 자동 설정
import matplotlib.pyplot as plt

plt.plot([1, 2, 3], [1, 4, 9])
plt.title('한글 제목')
plt.xlabel('X축')
plt.ylabel('Y축')
plt.show()

사용자 정의 폰트 사용

from helper_plot_hangul import matplotlib_font_set
import matplotlib.pyplot as plt

# 시스템 폰트 이름으로 설정
matplotlib_font_set(font_family='맑은 고딕')

# 또는 폰트 파일 경로로 설정
matplotlib_font_set(font_path='/path/to/font.ttf')

plt.plot([1, 2, 3], [1, 4, 9])
plt.title('사용자 정의 폰트 한글')
plt.show()

추가 옵션 설정

from helper_plot_hangul import matplotlib_font_set
import matplotlib.pyplot as plt

# matplotlib rcParams 추가 설정
matplotlib_font_set(
    font_family='NanumGothic',
    axes_unicode_minus=False,  # 마이너스 기호 깨짐 방지
    font_size=12,              # 기본 폰트 크기
)

plt.plot([1, 2, 3], [1, 4, 9])
plt.title('옵션 적용 한글')
plt.show()

스타일과 함께 사용

import helper_plot_hangul  # 한글 폰트 자동 설정
import matplotlib.pyplot as plt

# 스타일 적용 (한글 폰트 자동 유지)
plt.style.use('seaborn-v0_8-whitegrid')

plt.plot([1, 2, 3], [1, 4, 9])
plt.title('스타일 적용 + 한글')
plt.show()

NanumBarunGothic 폰트 사용

import helper_plot_hangul  # 기본 폰트: NanumGothic
import matplotlib.pyplot as plt

# NanumBarunGothic으로 전환
plt.rc("font", family="NanumBarunGothic")

plt.plot([1, 2, 3], [1, 4, 9])
plt.title('NanumBarunGothic 한글 제목')
plt.xlabel('X축')
plt.ylabel('Y축')
plt.show()

Jupyter/Colab에서 사용

# 첫 번째 셀에서 1회만 실행
import helper_plot_hangul

# 이후 모든 셀에서 plt 바로 사용 가능
import matplotlib.pyplot as plt

plt.plot([1, 2, 3], [1, 4, 9])
plt.title('주피터에서 한글')
plt.show()

선호 폰트만 등록 (리셋 없이)

from helper_plot_hangul import matplotlib_font_set

# matplotlib 리셋 없이 폰트만 변경
matplotlib_font_set(font_family='맑은 고딕', font_size=11)

API 레퍼런스

matplotlib_font_reset(font_family=None, font_path=None, **kwargs)

matplotlib를 완전히 리셋하고 한글 폰트를 설정합니다.

Parameters:

  • font_family (str, optional): 사용할 폰트 패밀리 이름 (기본값: 'NanumGothic', 추가 폰트: 'NanumBarunGothic')
  • font_path (str, optional): 폰트 파일 경로. 지정 시 파일에서 폰트 이름 추출
  • **kwargs: matplotlib rcParams에 전달할 추가 설정
    • axes_unicode_minus (bool): 마이너스 기호 깨짐 방지 (기본값: False)
    • font_size (int): 기본 폰트 크기 (기본값: 10)

Returns:

  • matplotlib.pyplot: 리셋되고 한글 폰트가 설정된 pyplot 모듈

폰트 설정 우선순위:

  1. font_path가 있으면 파일에서 폰트 패밀리 이름 추출
  2. font_family만 있으면 해당 이름 사용
  3. 둘 다 없으면 'NanumGothic' 기본값 사용 + 자동 탐색

matplotlib_font_set(font_family=None, font_path=None, **kwargs)

matplotlib를 리셋하지 않고 선호 폰트만 등록하고 즉시 적용합니다.

Parameters:

  • font_family (str, optional): 사용할 폰트 패밀리 이름
  • font_path (str, optional): 폰트 파일 경로
  • **kwargs: matplotlib rcParams에 전달할 추가 설정

작동 원리

  1. 폰트 자동 탐색: 패키지에 내장된 NanumGothic 폰트를 자동으로 찾아 로드
  2. 완전한 리셋: matplotlib 모듈을 완전히 리로드하여 폰트 캐시 클리어
  3. 스타일 패치: matplotlib.style.use 함수를 패치하여 스타일 적용 후 자동으로 한글 폰트 재설정
  4. 전역 등록: IPython 환경과 호출자 네임스페이스에 plt를 자동 등록

문제 해결

한글이 여전히 깨져 보이는 경우

# 1. 완전 리셋 시도 (폰트 캐시 문제 해결)
from helper_plot_hangul import matplotlib_font_reset
matplotlib_font_reset()

import matplotlib.pyplot as plt
plt.title('리셋 후 한글 확인')
plt.show()

# 2. 폰트 캐시 수동 삭제 (필요시)
import matplotlib.font_manager as fm
fm._get_fontconfig_fonts.cache_clear()

특정 폰트 사용하고 싶은 경우

from helper_plot_hangul import matplotlib_font_set
import matplotlib.pyplot as plt

# 시스템에 설치된 폰트 사용
matplotlib_font_set(font_family='D2Coding')

# 폰트 파일 직접 지정
matplotlib_font_set(font_path='/usr/share/fonts/custom.ttf')

plt.title('커스텀 폰트 한글')
plt.show()

사용되는 한글 폰트 경로 가져오기

from PIL import ImageFont
import reportlab.pdfbase.ttfonts as ttfonts

# 한글 폰트 가져오기
font_info = matplotlib_font_get()

# PIL에서 사용
if font_info['font_path']:
    pil_font = ImageFont.truetype(font_info['font_path'], size=12)

# ReportLab에서 사용
if font_info['font_path']:
    reportlab_font = ttfonts.TTFont('Hangul', font_info['font_path'])

요구사항

  • Python >= 3.8
  • matplotlib >= 3.2.0

라이센스

MIT License

기여

버그 리포트나 기능 제안은 GitHub Issues에 등록해주세요.

변경 이력

v0.5.0(2025-12-05)

  • 최초 릴리스
  • NanumGothic 폰트 내장
  • matplotlib 완전 리셋 기능
  • 스타일 호환성 자동 패치
  • Jupyter/Colab 최적화

v0.5.1(2025-12-09)

  • github 주소 변경

v0.5.2(2025-12-10)

  • jyupyter, colab 에서만 plot reset
  • 다른 환경에서는 폰트만 로딩

v0.5.3(2025-12-11)

  • 종속 라이브러리 설치

v0.5.6(2026-01-02)

  • 사용되는 한글 폰트 경로 가져오기

v0.5.7(2026-03-02)

  • import helper_plot_hangul 시 자동 초기화로 표준 사용법 지원
  • plt = matplotlib_font_reset() 반환값 할당 없이 import matplotlib.pyplot as plt 그대로 사용 가능

v0.5.8(2026-03-05)

  • NanumBarunGothic 폰트 추가
  • plt.rc("font", family="NanumGothic") 기본 폰트
  • plt.rc("font", family="NanumBarunGothic") 추가 폰트

v0.5.9(2026-05-18)

  • patch_style_use 함수 추가: matplotlib.style.use 호출 후 한글 폰트 자동 재적용
  • _style_patched 플래그 추가: 중복 패치 방지

jupyter_hangul를 참고하여 만들어졌습니다.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

helper_plot_hangul-0.5.9.tar.gz (4.6 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

helper_plot_hangul-0.5.9-py3-none-any.whl (4.6 MB view details)

Uploaded Python 3

File details

Details for the file helper_plot_hangul-0.5.9.tar.gz.

File metadata

  • Download URL: helper_plot_hangul-0.5.9.tar.gz
  • Upload date:
  • Size: 4.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for helper_plot_hangul-0.5.9.tar.gz
Algorithm Hash digest
SHA256 0ed079939c1513b3c0c7862f1888bb16a355e4fe3090defab3dbf2ab33a70fc2
MD5 98e997549ec68229a8c9be0fa08859e4
BLAKE2b-256 6443ce2834202f1ec885f50ce4a6e128cb1215d03c00120a36f6c15c8a7f0bf8

See more details on using hashes here.

File details

Details for the file helper_plot_hangul-0.5.9-py3-none-any.whl.

File metadata

File hashes

Hashes for helper_plot_hangul-0.5.9-py3-none-any.whl
Algorithm Hash digest
SHA256 ebc87ce66b5f066a590f22dcafbcafacf14d2bab3bc1fc8a4c004f08f905a83f
MD5 fa1e9c4bf376a3d582774f817428c0cf
BLAKE2b-256 bc6a551e57a9d5e2dbfbf53fdda70d286e958013fcfef332141acfbdaac9d269

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page