기본 콘텐츠로 건너뛰기

추천 가젯

리액트 + 비트(Vite)로 모바일 청첩장 만들기 — 2편

모바일 청첩장 시리즈 2편 · R2 갤러리 & Firebase 방명록 Cloudflare R2 · Functions Firebase Firestore 클라우드플레어 R2로 갤러리 저장하고, Firebase로 방명록 달기 안녕하세요, 병민입니다 🙌 1편에서 전체 흐름을 잡았고, 이번엔 사진 업로드/보관 과 방명록 을 연결합니다. 서버는 따로 없고 Cloudflare Pages 를 쓰고 있으니, Pages Functions (= 워커)로 R2에 사전서명 URL을 만들어주고, 프론트에서 그 URL로 바로 업로드하는 구조예요. 방명록은 Firebase DB로 간단·안전하게! 전체 그림 프론트(React) → /api/r2/upload 로 업로드용 URL 요청 → R2에 파일 PUT 프론트(React) → /api/r2/list 로 목록 요청 → 갤러리 렌더 프론트(React) → Firebase SDK로 방명록 작성/조회 1) R2 버킷 & Pages Functions 준비 Cloudflare 대시보드 > R2 > Create bucket (예: wedding-gallery ) 버킷 > Settings > CORS 에서 사이트 도메인 허용(예: https://*.pages.dev , 커스텀 도메인) Pages 프로젝트 > Settings > Functions 에서 R2 바인딩 추가: ...

📁 `pathlib`로 파일 경로를 객체처럼 다루자!

Pathlib icon

📁 `pathlib`로 파일 경로를 객체처럼 다루자!

pathlib는 파일 경로를 문자열이 아닌 `Path` 객체로 관리할 수 있게 해주는 모듈입니다. OS 간 호환성과 가독성을 모두 높여주며, 파일/디렉터리 작업을 직관적으로 처리할 수 있습니다.

✅ 1. 기본 `Path` 객체 생성 및 속성

from pathlib import Path

p = Path('/usr/local/bin')
print(p.name)       # bin
print(p.suffix)     # ''
print(p.stem)       # bin
print(p.parent)     # /usr/local
  • 객체 속성으로 경로 요소에 안전하게 접근 가능.

✅ 2. 파일 존재 확인, 생성, 삭제

p = Path('logs/app.log')
if not p.exists():
    p.parent.mkdir(parents=True, exist_ok=True)
    p.write_text('로그 시작\n', encoding='utf-8')
else:
    content = p.read_text(encoding='utf-8')
    print(content)
  • `.mkdir()`와 `exist_ok=True`로 안전한 폴더 생성.
  • 문자열 기반 입출력은 `.read_text()`, `.write_text()`로 간편하게.

✅ 3. 디렉터리 탐색 및 패턴 매칭

from pathlib import Path

for txt in Path('docs').rglob('*.txt'):
    print(txt, txt.stat().st_size, "bytes")
  • `rglob()` 덕분에 하위 폴더까지 포함한 확장자 일괄 탐색이 가능.

✅ 4. 파일 이동, 복사, 이름 변경

from shutil import copy2
from pathlib import Path

src = Path('data/report.txt')
dst = Path('backup/old_report.txt')
copy2(src, dst)    # 메타데이터 유지 복사

src.replace('archive/report.txt')  # 이동 및 덮어쓰기
  • 경로 연산과 `shutil` 조합으로 파일 조작을 안전하고 직관적으로.

✅ 5. 경로 결합, 절대 경로, 상대 경로 계산

from pathlib import Path

base = Path('/home/user')
sub = base / 'project' / 'main.py'
print(sub)                    # /home/user/project/main.py
print(sub.resolve())         # 절대경로 반환
print(sub.relative_to(Path('/home')))  # user/project/main.py
  • `/` 연산자를 사용한 경로 연결은 OS에 맞게 자동 변환됩니다.

✅ 6. 고급 예제: 로그 아카이브 자동화 스크립트

from pathlib import Path
import datetime

def archive_logs():
    today = datetime.date.today().isoformat()
    src = Path('logs')
    dst = Path(f'archive/logs_{today}')
    dst.mkdir(parents=True, exist_ok=True)
    for f in src.glob('*.log'):
        f.replace(dst / f.name)

archive_logs()
  • 날짜 기반 아카이브 폴더 자동 생성 + 로그 파일 이동.
  • 운영 환경 스크립트 예시로 실제 프로젝트에서 바로 응용 가능합니다.

✨ 요약 & 활용 팁

  • 모든 경로 작업을 객체로 처리 → 안전하고 직관적
  • `write_text` / `read_text` 등 입출력 기능 기본 탑재
  • `.glob()`, `.rglob()`로 패턴 탐색 작업 간편하게 처리
  • 경로 연산과 `shutil`, `datetime` 조합으로 실전 스크립트 작성 가능
  • OS 호환성 자동 관리 → Windows/Linux/macOS 모두 안전

댓글

가장 많이 본 글

Icons by Flaticon