我的创建事件管理 CLI 应用程序的旅程
我的创建事件管理 cli 应用程序的旅程
介绍
作为软件开发的初学者,最令人兴奋和艰巨的任务之一就是创建您的第一个重要项目。对我来说,这是事件管理 cli 应用程序。这个项目不仅帮助我巩固了对 python 的理解,还向我介绍了 sqlalchemy orm、click 等 cli 库以及软件开发的一般最佳实践。回顾这段旅程,我意识到我学到了很多东西,以及这些技能如何塑造了我作为开发人员的信心。
开始:学习 python 基础知识
在深入这个项目之前,我的旅程从 python 基础知识开始。学习 python 的语法、控制结构、数据类型和函数是解决这个项目的基础。我记得编写简单脚本、调试错误以及每次成功运行所带来的小胜利的日子。理解这些基础知识至关重要,因为它们构成了任何 python 项目的基石。
我早期学到的最有用的方面之一是如何管理和操作不同的数据结构,特别是列表、字典和元组。当我开始使用事件管理 cli 应用程序时,这些技能至关重要,我必须高效地存储和处理多个数据。
深入项目:设置环境
创建事件管理 cli 应用程序的第一步是设置环境。使用 pipenv 进行虚拟环境管理是一种全新的体验。它简化了管理依赖项的过程,并确保项目环境与系统的其他部分隔离。
这是我设置虚拟环境的方法:
pipenv installpipenv shell
接下来,我初始化了 alembic 以进行数据库迁移。此步骤对于管理数据库架构随时间的变化至关重要。
alembic init migrationsalembic revision --autogenerate -m "create initial models"alembic upgrade head
建立模型
应用程序的核心在于它的模型。使用 sqlalchemy orm,我定义了用户、事件、日程安排和与会者的模型。这就是我对 python 类和 sqlalchemy 的理解的结合点。这是 models.py 文件的片段:
from sqlalchemy import column, integer, string, foreignkey, datetime, create_enginefrom sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy.orm import relationship, sessionmakerbase = 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 定义表之间的关系可以更轻松地管理数据和执行查询。例如,在用户和事件之间建立一对多关系使我可以轻松查询特定用户创建的所有事件。
这是我如何定义 user 和 event 之间的关系:
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 clickfrom models import User, Event, EventSchedule, Attendeefrom 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 的基础知识开始,这为理解更复杂的概念奠定了基础。事件管理 cli 应用程序项目完美融合了 python、sql 和命令行界面,提供了全面的学习体验。
这个项目最大的收获之一是编码中结构和组织的重要性。使用虚拟环境、管理依赖关系并维护干净的项目结构使开发过程更加顺畅和高效。
此外,sqlalchemy orm 和 click 的实践经验强化了我所获得的理论知识。了解如何定义表之间的关系、执行数据库迁移以及创建用户友好的 cli 是非常宝贵的技能。
结论
创建事件管理 cli 应用程序是一次充满挑战但又有益的经历。它巩固了我对 python 和 sqlalchemy 的理解,向我介绍了软件开发的最佳实践,并增强了我解决问题的能力。对于任何想要成长为开发人员的初学者,我强烈建议深入研究这样的项目。这是应用您所学知识、发现新工具和技术以及构建令您引以为豪的有形事物的绝佳方式。
https://github.com/migsldev/event-management-app