本篇内容主要讲解“如何使用Go-Linq”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Go-Linq”吧!
go在进行集合操作时,有很不舒服的地方,起初我真的是无力吐槽,又苦于找不到一个好的第三方库,只能每次写着重复代码。举个栗子
类 学生{ 姓名 年龄 性别 }
1、现在有10个学生的数组,如果我要统计所有年龄大于20岁的人,那我需要
一、遍历
二、自定义条件
三、再append数组添加。
2、接着我又要统计性别为男的所有学生,我又要重复上面的步骤。
你说坑爹不坑爹,那是真的坑!
重点是95%的代码都是一样的,只是那百分之几有点区别。对于一名合格的程序员,我是坚决不能忍受这种情况的发生。
群里寻求大神帮助
混迹各大论坛,博客寻找有效信息
终于在老夫的不懈努力下,发现了一个库。它就是go-linq,使用它,能够解决我对集合大部分的需求,让编程更顺手,让工作更强经劲。
LINQ(发音:Link)是语言级集成查询(Language INtegrated Query)
•LINQ是一种用来进行数据访问的编程模型,使得.NET语言可以直接支持数据查询
Linq 是C#编程的一个爽的飞起的语法糖,使用过的人无一不对其高级的特性,偏自然语义化的折服。
那么问题来了,go有没有类似的东西呢,答案是肯定的,这次是我们马上要说的库Go-linq。通过这名称你就知道他是做什么的了。不多说了,直接开Lu。
一个强大的语言集成查询(LINQ)库的Go。
没有依赖!
使用迭代器模式完成延迟求值
对并发使用是安全的
支持泛型函数,使您的代码更干净,并且没有类型断言
支持数组、片、映射、字符串、通道和自定义集合
go get gopkg.in/ahmetb/go-linq.v3
import . "gopkg.in/ahmetb/go-linq.v3"
import . 的意思是直接使用库的方法,而不使用前缀。当然你也可以添加,官方的写法是这样的。
定义一个员工类
type Employee struct { Name string Age int Sex int // 0 男 1 女 WorkYear int //工龄 }
创建不同的列表
func initEmployeeData() []Employee { list := make([]Employee, 0) for i := 0; i < 10; i++ { list = append(list, Employee{ Name: "张" + strconv.Itoa(i%4), Age: 10 + i, Sex: i % 2, WorkYear: 1 + i%3, }) } return list } func initSameEployeeData() []Employee { list := make([]Employee, 0) for i := 0; i < 10; i++ { list = append(list, Employee{ Name: "张一", Age: 10, Sex: i % 2, WorkYear: 1, }) } return list }
func distinct() { var manEmpRows []Employee rows := initSameEployeeData() fmt.Println("===性别是男的所有员工列表去重===") From(rows).Distinct().ToSlice(&manEmpRows) fmt.Println(manEmpRows) }
===性别是男的所有员工列表去重=== [{张一 10 0 1} {张一 10 1 1}]
结果非常nice,本来我们需要的繁琐步骤,一个linq就解决了,是不是戝Diao!
//where 过滤条件 var manEmpRows []Employee fmt.Println("===过滤性别是男的员工===") From(rows).WhereT(func(e Employee) bool { return e.Sex == 0 }).ToSlice(&manEmpRows) fmt.Println(manEmpRows)
//Take 选取从头开始的几个元素 fmt.Println("===过滤性别是男的员工,只选择前俩个===") From(rows).WhereT(func(e Employee) bool { return e.Sex == 0 }).Take(2).ToSlice(&manEmpRows) fmt.Println(manEmpRows)
排序。单字段排序,多字段组合排序。
//where过滤+排序 fmt.Println("===过滤性别是女的员工,且按照工龄降序排序===") From(rows).WhereT(func(e Employee) bool { return e.Sex == 1 }).OrderByDescendingT(func(e Employee) int { return e.WorkYear }).ToSlice(&manEmpRows) fmt.Printf("%+v\n", manEmpRows) //where 过滤+双重排序 fmt.Println("===过滤性别是女的员工,且按照工龄降序排序,再按照年龄升序排序===") From(rows).WhereT(func(e Employee) bool { return e.Sex == 1 }).OrderByDescendingT(func(e Employee) int { return e.WorkYear }).ThenByT(func(e Employee) int { return e.Age }).ToSlice(&manEmpRows)
//只获取元素中的某些字段,list输出 var outputRows []string fmt.Println("===只获取元素中的某些字段,list输出===") From(rows).SelectT(func(e Employee) string { return e.Name }).ToSlice(&outputRows) fmt.Println(outputRows)
//聚合函数 query := From(rows).SelectT(func(e Employee) int { return e.Age }) fmt.Println(query.Average()) fmt.Println(query.Max()) fmt.Println(query.Min()) fmt.Println(query.Count())[]
//获取结构体数组首个元素或者末个 firstItem := From(rows).First() fmt.Println(firstItem) lastItem := From(rows).Last() fmt.Println(lastItem)
到此,相信大家对“如何使用Go-Linq”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。