나의 여정 이벤트 관리 CLI 앱 만들기
소개
소프트웨어 개발 초보자로서 가장 흥미롭고 어려운 작업 중 하나는 첫 번째 중요한 프로젝트를 만드는 것입니다. 나에게 이것은 Event Management CLI 애플리케이션이었습니다. 이 프로젝트는 Python에 대한 이해를 강화하는 데 도움이 되었을 뿐만 아니라 SQLAlchemy ORM, Click과 같은 CLI 라이브러리 및 소프트웨어 개발의 일반적인 모범 사례를 소개했습니다. 이번 여정을 되돌아보면 제가 얼마나 많은 것을 배웠는지, 그리고 이러한 기술이 개발자로서 제 자신감을 어떻게 형성했는지 깨달았습니다.
시작: Python의 기초 학습
이 프로젝트에 뛰어들기 전 나의 여정은 Python의 기본부터 시작되었습니다. Python의 구문, 제어 구조, 데이터 유형 및 기능을 배우는 것이 이 프로젝트를 가능하게 한 기초였습니다. 나는 간단한 스크립트를 작성하고, 오류를 디버깅하고, 모든 성공적인 실행에 따른 작은 승리를 누리던 시절을 기억합니다. 이러한 기본 사항을 이해하는 것은 모든 Python 프로젝트의 기반을 형성하기 때문에 매우 중요합니다.
초기에 배운 가장 유용한 측면 중 하나는 다양한 데이터 구조, 특히 목록, 사전 및 튜플을 관리하고 조작하는 방법이었습니다. 여러 데이터를 효율적으로 저장하고 처리해야 하는 이벤트 관리 CLI 앱 작업을 시작했을 때 이러한 기술은 필수적이었습니다.
프로젝트 자세히 알아보기: 환경 설정
이벤트 관리 CLI 앱을 만드는 첫 번째 단계는 환경을 설정하는 것이었습니다. 가상 환경 관리를 위해 Pipenv를 사용하는 것은 새로운 경험이었습니다. 종속성을 관리하는 프로세스를 간소화하고 프로젝트 환경이 내 시스템의 나머지 부분과 격리되도록 했습니다.
가상 환경을 설정하는 방법은 다음과 같습니다.
pipenv install pipenv shell
다음으로 데이터베이스 마이그레이션을 위해 Alembic을 초기화했습니다. 이 단계는 시간에 따른 데이터베이스 스키마 변경을 관리하는 데 매우 중요했습니다.
alembic init migrations alembic revision --autogenerate -m "Create Initial models" alembic upgrade head
모델 구축
애플리케이션의 핵심은 모델에 있습니다. SQLAlchemy ORM을 사용하여 사용자, 이벤트, 일정 및 참석자에 대한 모델을 정의했습니다. Python 클래스와 SQLAlchemy에 대한 나의 이해가 합쳐진 곳이 바로 여기였습니다. 다음은 models.py 파일의 일부입니다.
from sqlalchemy import Column, Integer, String, ForeignKey, DateTime, create_engine from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.orm import relationship, sessionmaker Base = declarative_base() class User(Base): __tablename__ = 'users' id = Column(Integer, primary_key=True) username = Column(String, unique=True, nullable=False) class Event(Base): __tablename__ = 'events' id = Column(Integer, primary_key=True) name = Column(String, nullable=False) description = Column(String) user_id = Column(Integer, ForeignKey('users.id')) user = relationship('User', back_populates='events') class EventSchedule(Base): __tablename__ = 'event_schedules' id = Column(Integer, primary_key=True) event_id = Column(Integer, ForeignKey('events.id')) start_time = Column(DateTime, nullable=False) end_time = Column(DateTime, nullable=False) event = relationship('Event', back_populates='schedules') class Attendee(Base): __tablename__ = 'attendees' id = Column(Integer, primary_key=True) name = Column(String, nullable=False) event_id = Column(Integer, ForeignKey('events.id')) event = relationship('Event', back_populates='attendees') User.events = relationship('Event', order_by=Event.id, back_populates='user') Event.schedules = relationship('EventSchedule', order_by=EventSchedule.id, back_populates='event') Event.attendees = relationship('Attendee', order_by=Attendee.id, back_populates='event')
유용한 기술적 측면: SQLAlchemy의 관계
이 프로젝트를 진행하면서 배운 가장 유용한 기술적 측면 중 하나는 SQLAlchemy에서 관계를 처리하는 것이었습니다. SQLAlchemy의 ORM을 사용하여 테이블 간의 관계를 정의하면 데이터 관리 및 쿼리 수행이 더 쉬워졌습니다. 예를 들어 사용자와 이벤트 사이에 일대다 관계를 구축하면 특정 사용자가 생성한 모든 이벤트를 쉽게 쿼리할 수 있었습니다.
사용자와 이벤트 간의 관계를 정의한 방법은 다음과 같습니다.
class User(Base): __tablename__ = 'users' id = Column(Integer, primary_key=True) username = Column(String, unique=True, nullable=False) events = relationship('Event', order_by='Event.id', back_populates='user') class Event(Base): __tablename__ = 'events' id = Column(Integer, primary_key=True) name = Column(String, nullable=False) description = Column(String) user_id = Column(Integer, ForeignKey('users.id')) user = relationship('User', back_populates='events')
이 관계 정의를 통해 사용자의 이벤트를 쉽게 쿼리할 수 있었습니다.
def get_user_events(user_id): user = session.query(User).filter(User.id == user_id).first() return user.events
CLI 구현
애플리케이션의 CLI 부분은 Click을 사용하여 구현되었습니다. 이 라이브러리를 사용하면 다양한 명령과 옵션을 처리할 수 있는 명령줄 인터페이스를 쉽게 만들 수 있습니다. 다음은 cli.py 파일의 일부입니다.
import click from models import User, Event, EventSchedule, Attendee from db import session @click.group() def cli(): pass @click.command() def create_event(): name = click.prompt('Enter event name') description = click.prompt('Enter event description') user_id = click.prompt('Enter user ID', type=int) event = Event(name=name, description=description, user_id=user_id) session.add(event) session.commit() click.echo('Event created!') cli.add_command(create_event) if __name__ == '__main__': cli()
뒤를 돌아보며
돌이켜보면 이 프로젝트는 개발자로서의 여정에 있어 중요한 이정표였습니다. Python의 기본을 배우는 것부터 시작하여 더 복잡한 개념을 이해하기 위한 기반을 마련했습니다. Event Management CLI 앱 프로젝트는 Python, SQL 및 명령줄 인터페이스가 완벽하게 혼합되어 포괄적인 학습 경험을 제공했습니다.
이 프로젝트에서 얻은 가장 큰 교훈 중 하나는 코딩에서 구조와 구성의 중요성이었습니다. 가상 환경을 사용하고 종속성을 관리하며 깔끔한 프로젝트 구조를 유지하면 개발 프로세스가 더욱 원활하고 효율적으로 진행됩니다.
게다가 SQLAlchemy ORM 및 Click에 대한 실무 경험을 통해 제가 얻은 이론적 지식이 더욱 강화되었습니다. 테이블 간의 관계를 정의하고, 데이터베이스 마이그레이션을 수행하고, 사용자 친화적인 CLI를 생성하는 방법을 이해하는 것은 매우 귀중한 기술이었습니다.
결론
이벤트 관리 CLI 애플리케이션을 만드는 것은 어려웠지만 보람 있는 경험이었습니다. Python과 SQLAlchemy에 대한 이해를 확고히 하고, 소프트웨어 개발의 모범 사례를 소개하고, 문제 해결 기술을 향상시켰습니다. 개발자로 성장하려는 초보자라면 이와 같은 프로젝트에 뛰어들 것을 적극 권장합니다. 이는 배운 내용을 적용하고, 새로운 도구와 기술을 발견하고, 자랑스러워할 수 있는 실질적인 무언가를 구축할 수 있는 훌륭한 방법입니다.
https://github.com/migsldev/event-management-app
위 내용은 나의 여정 이벤트 관리 CLI 앱 만들기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

이 기사에서는 HTML을 구문 분석하기 위해 파이썬 라이브러리 인 아름다운 수프를 사용하는 방법을 설명합니다. 데이터 추출, 다양한 HTML 구조 및 오류 처리 및 대안 (SEL과 같은 Find (), find_all (), select () 및 get_text ()와 같은 일반적인 방법을 자세히 설명합니다.

Python의 통계 모듈은 강력한 데이터 통계 분석 기능을 제공하여 생물 통계 및 비즈니스 분석과 같은 데이터의 전반적인 특성을 빠르게 이해할 수 있도록 도와줍니다. 데이터 포인트를 하나씩 보는 대신 평균 또는 분산과 같은 통계를보고 무시할 수있는 원래 데이터에서 트렌드와 기능을 발견하고 대형 데이터 세트를보다 쉽고 효과적으로 비교하십시오. 이 튜토리얼은 평균을 계산하고 데이터 세트의 분산 정도를 측정하는 방법을 설명합니다. 달리 명시되지 않는 한,이 모듈의 모든 함수는 단순히 평균을 합산하는 대신 평균 () 함수의 계산을 지원합니다. 부동 소수점 번호도 사용할 수 있습니다. 무작위로 가져옵니다 수입 통계 Fracti에서

이 기사는 딥 러닝을 위해 텐서 플로와 Pytorch를 비교합니다. 데이터 준비, 모델 구축, 교육, 평가 및 배포와 관련된 단계에 대해 자세히 설명합니다. 프레임 워크, 특히 계산 포도와 관련하여 주요 차이점

이 기사는 Numpy, Pandas, Matplotlib, Scikit-Learn, Tensorflow, Django, Flask 및 요청과 같은 인기있는 Python 라이브러리에 대해 설명하고 과학 컴퓨팅, 데이터 분석, 시각화, 기계 학습, 웹 개발 및 H에서의 사용에 대해 자세히 설명합니다.

이 기사는 Python 개발자가 CLIS (Command-Line Interfaces) 구축을 안내합니다. Typer, Click 및 Argparse와 같은 라이브러리를 사용하여 입력/출력 처리를 강조하고 CLI 유용성을 향상시키기 위해 사용자 친화적 인 디자인 패턴을 홍보하는 세부 정보.

Python의 Pandas 라이브러리를 사용할 때는 구조가 다른 두 데이터 프레임 사이에서 전체 열을 복사하는 방법이 일반적인 문제입니다. 두 개의 dats가 있다고 가정 해

이 기사는 프로젝트 종속성 관리 및 충돌을 피하는 데 중점을 둔 Python에서 가상 환경의 역할에 대해 설명합니다. 프로젝트 관리 개선 및 종속성 문제를 줄이는 데있어 생성, 활성화 및 이점을 자세히 설명합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

뜨거운 주제



