登录
首页 >  Golang >  Go问答

等效于 Python 的列表推导

来源:Golang技术栈

时间:2023-04-19 19:16:44 489浏览 收藏

你在学习Golang相关的知识吗?本文《等效于 Python 的列表推导》,主要介绍的内容就涉及到golang,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

问题内容

我正在玩围棋,但我很难做其他语言非常简单的事情。

我想重现一个[Python 理解](https://docs.python.org/3/tutorial/datastructures.html#list- comprehensions):

array = [a for a in anotherArray  if (some condition)]

在 Go 中有什么优雅的方法?我真的很想简化我的代码,尤其是在数组上使用函数时。例如:

min = min(abs(a[i], b[j]) for i in range(n)
                          for j in range(i, n))

正确答案

有趣的是,Rob Pike刚刚(18 小时前)提出了库过滤器,它可以满足您的需求:

参见例如选择()

// Choose takes a slice of type []T and a function of type func(T) bool. (If
// the input conditions are not satisfied, Choose panics.) It returns a newly
// allocated slice containing only those elements of the input slice that
// satisfy the function.

在这里测试

func TestChoose(t *testing.T) {
    a := []int{1, 2, 3, 4, 5, 6, 7, 8, 9}
    expect := []int{2, 4, 6, 8}
    result := Choose(a, isEven)

正如[评论中](https://stackoverflow.com/questions/27848406/golang-equivalent-for- pythons-list- comprehension#comment44102741_27848524)twotwotwo指出的那样,该库的GoDoc指出:[](https://stackoverflow.com/questions/27848406/golang- equivalent-for-pythons-list- comprehension#comment44102741_27848524)

filter包含用于通过过滤器功能的分布式应用过滤切片的实用程序功能。

这个包是一个实验,看看用 Go 编写这样的东西是多么容易。这很容易,但 for 循环同样简单且更有效

你不应该使用这个包。

这一警告反映在文档“ [Go 泛型讨论摘要](https://docs.google.com/document/d/1vrAy9gMpMoS3uaVphB32uVXX4pi- HnNjkMEgyAHX4N4/mobilebasic?pli=1) ”的“[ 功能代码](https://docs.google.com/document/d/1vrAy9gMpMoS3uaVphB32uVXX4pi- HnNjkMEgyAHX4N4/mobilebasic?pli=1#h.97ujgd64iyd) ”部分:

这些是通常的高阶函数,例如map, reduce( fold),filterzip

案例 :类型安全的
数据转换:map,,,fold``zip

使用泛型的优点
表达数据转换的简洁方式。

使用泛型的缺点
最快的解决方案需要考虑应用这些转换的时间和顺序,以及每一步生成多少数据。
初学者更难阅读。

替代解决方案

使用for循环和通常的语言结构


2022 年第一季度更新:随着 Go 中首次集成泛型(例如,参见“教程:泛型入门”),您现在可以在 Go 中使用泛型实现 mapreduce
请参阅tip.playgroundgithub.com/kevwan/mapreduce/v2项目。

本篇关于《等效于 Python 的列表推导》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表