”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 我的第一个 CLI。

我的第一个 CLI。

发布于2024-11-03
浏览:982

My first CLI.

片头字幕

一旦一切顺利,就认为这个项目很有趣。我构建了一个客户端友好的 CLI 项目来掌握类、方法和属性的工作原理。

我的目录结构非常简单:

└── lib
├── 型号
│ ├── __init__.py
│ └── actor.py
| └── 电影.py
├── cli.py
├── 调试.py
└── helpers.py
├── Pipfile
├── Pipfile.lock
├── README.md

正如您从结构中看到的,我建立了一个一对多关联,其中一个演员有很多电影。从这个协会我的菜单开始发挥作用。

  1. 当前演员名单
  2. 添加演员
  3. 删除演员
  4. 退出程序

上面的菜单是由一个名为... menu() 的函数定义的,该函数位于我的 cli.py 文件中,与向用户显示 CLI 菜单的 main() 一起:

def main():
    while True:
        welcome()
        menu()
        choice = input("> ").strip()
        if choice == "1":
            actor_list()
        elif choice == "2":
            add_actor()
        elif choice == "3":
            delete_actor()
        elif choice == "4":
            exit_program()
            break
        else:
            print("Invalid choice. Try again.\n")

这个特殊的函数是许多函数中的第一个,其中执行 while 循环和 if/elif/else 语句,以使我们的用户能够轻松导航我们的菜单。

然后 cli.py 以一些重要的代码块结束:

if __name__ == "__main__":
    main() 

此代码块告诉我们的解释器 (Python) 仅在从命令行调用文件时运行我们的文件。

配角

这个项目中还涉及辅助函数,它们也使用了 while 循环以及 if/elif/else 语句。其中一个特别引人注目的是,在选择我们当前的演员列表时显示出导航的便利性:

def actor_list():

        actor_list = Actor.get_all()

        if actor_list:
            print("\n*** UPDATED LIST! ***")
            for i, actor in enumerate(actor_list, start=1):
                print(f"{i}. {actor.name}")  

            while True:
                choice = input("Press 'a' to add an actor\n"
                                "Press 'b' for actor profile\n"
                                "Press 'c' to return to the main menu.\n"
                                "Press 'd' delete an actor.\n").lower()
                if choice == 'a':
                    add_actor()
                    break
                elif choice == 'b':
                    actor_profile()
                    break
                elif choice == 'c':
                    return
                elif choice == 'd':
                    delete_actor()
                    break
                else:
                    print("Invalid choice. Please try again.") 
        else:
            print("List empty!")
            while True:
                choice = input("Press 'a' or to add an actor\n"
                        "Press 'b' for main menu.\n").lower()
                if choice == 'a':
                    add_actor()
                    break
                elif choice == 'b':
                    return
                else:
                    print("Invalid choice. Please try again.")

在这里,我不仅习惯了 while 循环和 if 语句,而且还通过使用 enumerate() 和 for 循环来迭代 python 中的索引,从而允许所有列表通过项目,从而获得外观和顺序的好处成为一个有序列表。

显示一些类

我们的两个主要角色当然是演员类和电影类。在创建、更新或删除特定类的实例时,两者在类方法方面都包含相似的代码,但存在差异:

以我们的 Movie 类为例:

class Movie:

    all_movies = {}

    def __init__(self, movie, genre, actor_id, id=None):
        self.id = id
        self.movie = movie
        self.genre = genre
        self.actor_id = actor_id

由于我们的项目设置中一个演员有很多电影,所以我们的电影类将有一个唯一的 actor_id 参数/属性来建立电影实例和特定演员之间的链接,从而可以轻松引用演员的信息。

现在看看我们的 Actor 类中的这个代码块:

   def movies(self):
        from models.movie import Movie
        sql = """
            SELECT * FROM movie
            WHERE actor_id = ?
        """
        CURSOR.execute(sql, (self.id,),)

        rows = CURSOR.fetchall()
        return [
            Movie.instance_from_db(row) for row in rows
        ]

这里,我们的 movie() 方法通过使用演员的 ID 查询电影表来检索与当前 Actor 实例关联的所有电影。然后,这将返回 Movie 对象的列表,在 Actor 和 Movie 之间建立“有多”关系。

讨论的代码块是该项目的主要领域,我专注于掌握更多理解。总的来说,这个项目是一个很好的练习,可以增强我的 python 技能。

版本声明 本文转载于:https://dev.to/wormondeck/my-first-cli-2if?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-15
  • 对 MySQL 结果进行分组:SQL 与 PHP - 哪种方法最好?
    对 MySQL 结果进行分组:SQL 与 PHP - 哪种方法最好?
    MySQL 按字段数据对结果进行分组:SQL 与 PHP 方法在数据管理领域,可能会出现需要按字段数据对数据库结果进行分组的情况,并且以特定格式显示它们。请考虑以下示例:示例 1:根据组 ID 组织名称列表:示例 2:根据公共组 ID 配对相应的标题和系数值:为了解决这些挑战,出现了两种主要方法:S...
    编程 发布于2024-11-15
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-15
  • 如何推迟加载大型 CSS 文件以提高页面性能?
    如何推迟加载大型 CSS 文件以提高页面性能?
    优化CSS交付:了解延迟CSS加载优化CSS交付时,在页面加载后延迟加载大型CSS文件可以显着提高页面性能。虽然 Google 开发人员提供的示例演示了内联小型 CSS 文件以实现关键样式,但它留下了如何推迟较大 CSS 文件的问题。加载后访问原始 CSS 文件要将大型 CSS 文件的加载推迟到页面...
    编程 发布于2024-11-15
  • Javascript 基元实际上是对象吗?
    Javascript 基元实际上是对象吗?
    Javascript 基元与对象:澄清概念尽管普遍认为“Javascript 中几乎所有内容都是对象”,但并非所有内容语言中的实体遵循这个定义。基元和对象之间的区别需要澄清。基元与对象相反,基元是以其基本形式存在的不可变值。它们缺少方法和属性,并包括以下数据类型:StringsNumbersBool...
    编程 发布于2024-11-15
  • 为什么 C++ 中的联合内禁止使用 `std::string` 对象?
    为什么 C++ 中的联合内禁止使用 `std::string` 对象?
    为什么 std::string 在联合中被禁止在 C 编程领域,联合是一种特殊的结构,它允许在联合中存储各种数据类型共享内存地址。然而,当涉及联合中的成员时,有一个有趣的限制:禁止具有非平凡构造函数的类,包括 std::string。非平凡构造函数的问题根本原因可以追溯到工会的性质。联合体中的成员从...
    编程 发布于2024-11-15
  • 我们能否在正则表达式中实现真正的可变长度向后查找?
    我们能否在正则表达式中实现真正的可变长度向后查找?
    正则表达式的可变长度回顾断言替代方案正则表达式中的可变长度回顾断言,用 (?带有正则表达式模块的 PythonPython 正则表达式模块提供对可变长度后向断言的支持。 import regex m = regex.search('(?<!foo.*)bar', 'f00bar') p...
    编程 发布于2024-11-15
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1和$array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求是构...
    编程 发布于2024-11-15
  • 如何使用 Twitter Bootstrap 对齐表格中的文本?
    如何使用 Twitter Bootstrap 对齐表格中的文本?
    Twitter Bootstrap 中的表格文本对齐在 Twitter 的 Bootstrap 框架中,您可以使用指定的文本对齐类来对齐表格内的文本。 Bootstrap 3text-left:左对齐文本text-center:居中对齐文本text-right:右对齐文本Bootstrap 4tex...
    编程 发布于2024-11-15
  • 除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为 bool 的主要场景:语句:if、w...
    编程 发布于2024-11-15
  • 如何使 CSS 中的空表格单元格的边框可见?
    如何使 CSS 中的空表格单元格的边框可见?
    我可以在 CSS 中使空单元格的边框可见吗?在 Internet Explorer 7 中,默认情况下可能不会显示空单元格的边框。不过,有几种方法可以解决此问题。使用不间断空格如果可行,请插入不间断空格 ( )进入空单元格可以强制浏览器渲染带有边框的单元格。纯 CSS 解决方案对于纯 CS...
    编程 发布于2024-11-15
  • 如何将 Python 列表转换为 CSV 文件?
    如何将 Python 列表转换为 CSV 文件?
    将 Python 列表列表导出到 CSV 文件您的目标是将 Python 列表列表转换为 CSV 文件,确保每个子列表中都会保留不同类型(浮点型、整数型、字符串型)的数据。所需的 CSV 格式涉及使用逗号分隔每个子列表中的元素并垂直对齐子列表。要实现此目的,您可以利用 Python 的内置 csv ...
    编程 发布于2024-11-15
  • 测试限制:了解软件测试的边界
    测试限制:了解软件测试的边界
    软件测试是确保软件质量、稳定性和功能的开发过程的重要组成部分。然而,尽管测试很重要,但它也有其局限性。虽然它可以揭示缺陷,但它不能保证应用程序完全没有错误。了解这些限制有助于企业和开发人员设定切合实际的期望并优化他们的测试流程。在本文中,我们将探讨软件测试的主要局限性及其带来的挑战。 无法测试每个...
    编程 发布于2024-11-15
  • 如何有效地将文件加载到`std::vector`中?
    如何有效地将文件加载到`std::vector`中?
    高效地将文件加载到 std::vector高效地将文件加载到 std::vector,必须避免不必要的复制和内存重新分配。虽然利用 Reserve 和 read() 的原始方法可能看起来很直接,但单独的 Reserve() 并不会改变向量的容量。使用迭代器的规范方法:规范方法使用输入流迭代器来方便地...
    编程 发布于2024-11-15
  • 如何在 Go 中将数组元素直接解压为变量?
    如何在 Go 中将数组元素直接解压为变量?
    在 Go 中解包数组元素Go 缺乏将数组元素直接解包到 Python 中的变量的便捷语法。虽然提问者使用中间变量的初始方法有效,但它可能会导致代码混乱,尤其是在复杂的场景中。多个返回值为了解决这个问题,建议使用解决方案是创建一个返回多个值的函数。例如,要拆分字符串并将结果解压为两个变量,可以使用如下...
    编程 发布于2024-11-15

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3