Maison >développement back-end >Tutoriel Python >Mon parcours en créant une application CLI de gestion d'événements

Mon parcours en créant une application CLI de gestion d'événements

王林
王林original
2024-08-08 16:20:58772parcourir

My Journey Creating an Event Management CLI App

Mon parcours en créant une application CLI de gestion d'événements

Introduction

En tant que débutant dans le développement de logiciels, l'une des tâches les plus excitantes et les plus ardues consiste à créer votre premier projet important. Pour moi, il s’agissait de l’application CLI de gestion d’événements. Ce projet m'a non seulement aidé à consolider ma compréhension de Python, mais m'a également présenté SQLAlchemy ORM, les bibliothèques CLI comme Click et les meilleures pratiques générales de développement logiciel. En réfléchissant à ce voyage, je réalise combien j'ai appris et comment ces compétences ont façonné ma confiance en soi en tant que développeur.

Les débuts : apprendre les principes fondamentaux de Python

Avant de me lancer dans ce projet, mon parcours a commencé par les bases de Python. L'apprentissage de la syntaxe, des structures de contrôle, des types de données et des fonctions de Python a constitué la base qui a rendu possible la réalisation de ce projet. Je me souviens de l'époque où l'on écrivait des scripts simples, des erreurs de débogage et des petites victoires qui accompagnaient chaque exécution réussie. Comprendre ces principes fondamentaux était crucial car ils constituent le fondement de tout projet Python.

L'un des aspects les plus utiles que j'ai appris dès le début était de savoir comment gérer et manipuler différentes structures de données, en particulier les listes, les dictionnaires et les tuples. Ces compétences étaient essentielles lorsque j'ai commencé à travailler sur l'application CLI Event Management, où je devais stocker et gérer efficacement plusieurs éléments de données.

Plonger dans le projet : configurer l'environnement

La première étape de la création de l'application CLI de gestion d'événements consistait à configurer l'environnement. Utiliser Pipenv pour la gestion de l'environnement virtuel était une nouvelle expérience. Cela a rationalisé le processus de gestion des dépendances et garanti que l'environnement du projet était isolé du reste de mon système.

Voici comment j'ai configuré l'environnement virtuel :

pipenv install
pipenv shell

Ensuite, j'ai initialisé Alembic pour les migrations de bases de données. Cette étape était cruciale pour gérer les modifications du schéma de base de données au fil du temps.

alembic init migrations
alembic revision --autogenerate -m "Create Initial models"
alembic upgrade head

Construire les modèles

Le cœur de l'application réside dans ses modèles. À l'aide de SQLAlchemy ORM, j'ai défini les modèles pour les utilisateurs, les événements, les horaires et les participants. C'est là que ma compréhension des classes Python et de SQLAlchemy s'est réunie. Voici un extrait du fichier 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')

Un aspect technique utile : les relations dans SQLAlchemy

L'un des aspects techniques les plus utiles que j'ai appris au cours de ce projet était la gestion des relations dans SQLAlchemy. La définition des relations entre les tables à l'aide de l'ORM de SQLAlchemy a facilité la gestion des données et l'exécution des requêtes. Par exemple, établir une relation un-à-plusieurs entre les utilisateurs et les événements m'a permis d'interroger facilement tous les événements créés par un utilisateur spécifique.

Voici comment j'ai défini la relation entre l'utilisateur et l'événement :

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')

Cette définition de relation m'a permis d'interroger facilement les événements d'un utilisateur :

def get_user_events(user_id):
    user = session.query(User).filter(User.id == user_id).first()
    return user.events

Implémentation de la CLI

La partie CLI de l'application a été implémentée à l'aide de Click. Cette bibliothèque a facilité la création d'une interface de ligne de commande capable de gérer diverses commandes et options. Voici un extrait du fichier 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()

Regarder en arrière

Avec le recul, ce projet a été une étape importante dans mon parcours en tant que développeur. Cela a commencé par l’apprentissage des principes fondamentaux de Python, qui ont jeté les bases de la compréhension de concepts plus complexes. Le projet d'application CLI de gestion d'événements était un mélange parfait d'interfaces Python, SQL et de ligne de commande, offrant une expérience d'apprentissage complète.

L'un des principaux enseignements de ce projet était l'importance de la structure et de l'organisation dans le codage. L'utilisation d'environnements virtuels, la gestion des dépendances et le maintien d'une structure de projet propre ont rendu le processus de développement plus fluide et plus efficace.

De plus, l'expérience pratique avec SQLAlchemy ORM et Click a renforcé les connaissances théoriques que j'avais acquises. Comprendre comment définir les relations entre les tables, effectuer des migrations de bases de données et créer une CLI conviviale étaient des compétences inestimables.

Conclusion

La création de l'application CLI de gestion d'événements a été une expérience à la fois difficile et enrichissante. Cela a solidifié ma compréhension de Python et SQLAlchemy, m'a présenté les meilleures pratiques en matière de développement de logiciels et amélioré mes compétences en résolution de problèmes. Pour tout débutant cherchant à évoluer en tant que développeur, je recommande fortement de se lancer dans un projet comme celui-ci. C'est un excellent moyen d'appliquer ce que vous avez appris, de découvrir de nouveaux outils et techniques et de construire quelque chose de tangible dont vous pouvez être fier.

https://github.com/migsldev/event-management-app

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn