搜索
首页后端开发Golang简单的 Go CLI-一切应用程序

嘿伙计们!

我已经两年多没有写关于 Dev 的博客了!已经有一段时间了,如果我的打字能力随着时间的推移而下降,请原谅。

我目前正在学习 Go,并收到了要完成和分享的项目列表,其中一个恰好是一个简单的 Golang cli-todo 应用程序,它允许某人将待办事项添加到任务列表中并实现一组基本功能这些任务的功能。

其中包括:

1) 列出任务
2) 添加更多任务
3)修改这些任务
4)使任务完成

不幸的是,我没有一个好听的名字?因为它被设计成一个轻量级、易于使用的应用程序,某人可以在一天内完成。即使您是初学者。

Simple Go CLI-Todo App

~ 项目源代码:https://github.com/SirTingling/cloudprojects/tree/main/go-cli-todo-app

让我们开始吧

像往常一样,创建我们的 main.go。设置完成后,我们需要定义待办事项的结构和功能。我在单独的 todo.go 中这样做了

type Todo struct {
    Title       string
    Completed   bool
    CreatedAt   time.Time
    CompletedAt *time.Time
}

用一片来存放我们的待办事项

type Todos []Todo

然后我们需要实现主要功能方法,其中包括:

  • 添加
func (todos *Todos) add(title string) {
    todo := Todo{
        Title:       title,
        Completed:   false,
        CompletedAt: nil,
        CreatedAt:   time.Now(),
    }

    *todos = append(*todos, todo)
}

创建一个带有标题的 Todo 对象,将其 Completed 状态设置为 false,并将其附加到 Todos 切片。

  • 删除
func (todos *Todos) delete(index int) error {
    t := *todos

    if err := t.validateIndex(index); err != nil {
        return err
    }

    *todos = append(t[:index], t[index+1:]...)

    return nil
}

验证索引,然后使用切片从待办事项列表中删除该项目。

  • 切换
func (todos *Todos) toggle(index int) error {
    if err := todos.validateIndex(index); err != nil {
        return err
    }

    t := *todos
    todo := &t[index]

    if !todo.Completed {
        completedTime := time.Now()
        todo.CompletedAt = &completedTime
    } else {
        todo.CompletedAt = nil
    }

    todo.Completed = !todo.Completed
    return nil
}

验证索引,翻转 Completed 布尔值,并相应地更新 CompletedAt 时间戳。

其余方法的功能非常相似,如果有任何问题,请随时查看源代码

运行应用程序

许多基于 cli 的待办事项应用程序的一个常见问题是它们不那么迷人。在名为 aquasecurity/table 的第三方软件包的帮助下,待办事项列表将整齐地显示。

水产安全/桌子

它可以安装:

go get github.com/aquasecurity/table

然后我制作了一种使用包外部的方法来显示待办事项的方法。特别是 SetRowLines、SetHeaders、New、AddRow 和 Render 是我的案例中主要使用的。

func (todos *Todos) print() {
    table := table.New(os.Stdout)
    table.SetRowLines(false)
    table.SetHeaders("#", "Title", "Completed", "Created At", "Completed At")

    for index, t := range *todos {
        completed := "❌"
        completedAt := ""

        if t.Completed {
            completed = "✅"
            if t.CompletedAt != nil {
                completedAt = t.CompletedAt.Format(time.RFC1123) //time standard
            }
        }

        table.AddRow(strconv.Itoa(index), t.Title, completed, t.CreatedAt.Format(time.RFC1123), completedAt)
    }

    table.Render()
}

print 方法是在终端中显示待办事项列表的一种巧妙方法。它创建一个表,其中包含任务编号、标题、任务是否完成、创建时间和完成时间等列。

它会遍历每个待办事项,检查是否已完成,如果已完成则添加 ✅,如果未完成则添加 ❌。如果任务完成,它甚至会显示完成的确切日期和时间。

一旦所有行都准备好,它就会以干净、可读的格式打印表格。超级方便,一目了然地快速查看所有用户任务的状态!

保存这些待办事项怎么样?

所以我认为将待办事项本地保存到一个文件(在本例中为 todos.json)然后从那里读取的功能是一个好主意。本质上,我们的每项待办事项数据都具有一定程度的持久性。

我们可以将此功能添加到现有文件中,但我认为分离关注点是个好主意。

我添加了一个storage.go,你可以将其命名为store.go、persist.go等。

我选择了 JSON,但相同的原则通常也适用于您想要保存数据的任何数据格式。

type Todo struct {
    Title       string
    Completed   bool
    CreatedAt   time.Time
    CompletedAt *time.Time
}
  • 有一个 存储 结构来跟踪正在使用的文件。

  • NewStorage 函数只需提供文件名即可帮助进行设置。

  • Save 方法获取数据,将其转换为漂亮的 JSON,并将其写入文件 (todos.json)。如果出现问题,它会告诉我们一个错误。

  • Load 方法执行相反的操作 - 读取文件、解压 JSON,并用数据填充 fileData。

这是一种简单、可重用的方法来处理保存和加载任何类型的数据,而不需要数据库或任何花哨的东西。

从这里开始,我使用 main.go 中的 NewStorage 将一些待办事项添加到我的列表中并保存它们,现在可以在我的 todos.json 中查看它们

type Todos []Todo

func (todos *Todos) add(title string) {
    todo := Todo{
        Title:       title,
        Completed:   false,
        CompletedAt: nil,
        CreatedAt:   time.Now(),
    }

    *todos = append(*todos, todo)
}

对于命令,我没有做任何花哨的事情。我定义了将用作结构的标志

func (todos *Todos) delete(index int) error {
    t := *todos

    if err := t.validateIndex(index); err != nil {
        return err
    }

    *todos = append(t[:index], t[index+1:]...)

    return nil
}

然后使用标志包的一个简单函数列出这些标志,为它们提供更多详细信息和描述,并自定义它们。我还听说了 Cobra 软件包的好消息,它在这里非常容易使用,下次我会尝试一下。

func (todos *Todos) toggle(index int) error {
    if err := todos.validateIndex(index); err != nil {
        return err
    }

    t := *todos
    todo := &t[index]

    if !todo.Completed {
        completedTime := time.Now()
        todo.CompletedAt = &completedTime
    } else {
        todo.CompletedAt = nil
    }

    todo.Completed = !todo.Completed
    return nil
}

从那里,您可以发挥创意来执行这些标志,在我的例子中,我做了简单的 case 语句。

就是这样?

是的!这样就完成了这个简单的 Go cli 待办事项应用程序,它可以在相对较短的时间内完成,主要感谢 与 Patrik 一起编码The Builder 两者都有令人惊叹的内容,可帮助完成此类项目并使其变得有趣!

感谢您的阅读,我希望这些迷你项目能够激励其他人开始使用 Go 或继续练习它。我还有一些事情要做和分享,我们下次见!

Simple Go CLI-Todo App

以上是简单的 Go CLI-一切应用程序的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
测试代码依赖于INET功能的代码测试代码依赖于INET功能的代码May 03, 2025 am 12:20 AM

whentestinggocodewithinitfunctions,useexplicitseTupfunctionsorseParateTestFileSteSteTepteTementDippedDependendendencyOnInItfunctionsIdeFunctionSideFunctionsEffect.1)useexplicitsetupfunctionStocontrolglobalvaribalization.2)createSepEpontrolglobalvarialization

将GO的错误处理方法与其他语言进行比较将GO的错误处理方法与其他语言进行比较May 03, 2025 am 12:20 AM

go'serrorhandlingurturnserrorsasvalues,与Javaandpythonwhichuseexceptions.1)go'smethodensursexplitirorhanderling,propertingrobustcodebutincreasingverbosity.2)

设计有效界面的最佳实践设计有效界面的最佳实践May 03, 2025 am 12:18 AM

AnefactiveInterfaceoisminimal,clear and promotesloosecoupling.1)minimizeTheInterfaceForflexibility andeaseofimplementation.2)useInterInterfaceForeabStractionTosWapImplementations withCallingCallingCode.3)

集中式错误处理策略集中式错误处理策略May 03, 2025 am 12:17 AM

集中式错误处理在Go语言中可以提升代码的可读性和可维护性。其实现方式和优势包括:1.将错误处理逻辑从业务逻辑中分离,简化代码。2.通过集中处理错误,确保错误处理的一致性。3.使用defer和recover来捕获和处理panic,增强程序健壮性。

init in Init函数的替代方案,用于go中的包装初始化init in Init函数的替代方案,用于go中的包装初始化May 03, 2025 am 12:17 AM

Ingo,替代词Inivuntionsionializatializatializationfunctionsandsingletons.1)customInitializationfunctions hallowexpliticpliticpliticconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconconcontirization curssementializatizatupsetups.2)单次固定元素限制ininconinconcurrent

与GO接口键入断言和类型开关与GO接口键入断言和类型开关May 02, 2025 am 12:20 AM

Gohandlesinterfacesandtypeassertionseffectively,enhancingcodeflexibilityandrobustness.1)Typeassertionsallowruntimetypechecking,asseenwiththeShapeinterfaceandCircletype.2)Typeswitcheshandlemultipletypesefficiently,usefulforvariousshapesimplementingthe

使用errors.is和错误。使用errors.is和错误。May 02, 2025 am 12:11 AM

Go语言的错误处理通过errors.Is和errors.As函数变得更加灵活和可读。1.errors.Is用于检查错误是否与指定错误相同,适用于错误链的处理。2.errors.As不仅能检查错误类型,还能将错误转换为具体类型,方便提取错误信息。使用这些函数可以简化错误处理逻辑,但需注意错误链的正确传递和避免过度依赖以防代码复杂化。

在GO中进行性能调整:优化您的应用程序在GO中进行性能调整:优化您的应用程序May 02, 2025 am 12:06 AM

tomakegoapplicationsRunfasterandMorefly,useProflingTools,leverageConCurrency,andManageMoryfectily.1)usepprofforcpuorforcpuandmemoryproflingtoidentifybottlenecks.2)upitizegorizegoroutizegoroutinesandchannelstoparalletaparelalyizetasksandimproverperformance.3)

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境