您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“如何使用Go-Linq”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“如何使用Go-Linq”吧!
go在進(jìn)行集合操作時(shí),有很不舒服的地方,起初我真的是無力吐槽,又苦于找不到一個(gè)好的第三方庫,只能每次寫著重復(fù)代碼。舉個(gè)栗子
類 學(xué)生{ 姓名 年齡 性別 }
1、現(xiàn)在有10個(gè)學(xué)生的數(shù)組,如果我要統(tǒng)計(jì)所有年齡大于20歲的人,那我需要
一、遍歷
二、自定義條件
三、再append數(shù)組添加。
2、接著我又要統(tǒng)計(jì)性別為男的所有學(xué)生,我又要重復(fù)上面的步驟。
你說坑爹不坑爹,那是真的坑!
重點(diǎn)是95%的代碼都是一樣的,只是那百分之幾有點(diǎn)區(qū)別。對(duì)于一名合格的程序員,我是堅(jiān)決不能忍受這種情況的發(fā)生。
群里尋求大神幫助
混跡各大論壇,博客尋找有效信息
終于在老夫的不懈努力下,發(fā)現(xiàn)了一個(gè)庫。它就是go-linq,使用它,能夠解決我對(duì)集合大部分的需求,讓編程更順手,讓工作更強(qiáng)經(jīng)勁。
LINQ(發(fā)音:Link)是語言級(jí)集成查詢(Language INtegrated Query)
?LINQ是一種用來進(jìn)行數(shù)據(jù)訪問的編程模型,使得.NET語言可以直接支持?jǐn)?shù)據(jù)查詢
Linq 是C#編程的一個(gè)爽的飛起的語法糖,使用過的人無一不對(duì)其高級(jí)的特性,偏自然語義化的折服。
那么問題來了,go有沒有類似的東西呢,答案是肯定的,這次是我們馬上要說的庫Go-linq。通過這名稱你就知道他是做什么的了。不多說了,直接開Lu。
一個(gè)強(qiáng)大的語言集成查詢(LINQ)庫的Go。
沒有依賴!
使用迭代器模式完成延遲求值
對(duì)并發(fā)使用是安全的
支持泛型函數(shù),使您的代碼更干凈,并且沒有類型斷言
支持?jǐn)?shù)組、片、映射、字符串、通道和自定義集合
go get gopkg.in/ahmetb/go-linq.v3
import . "gopkg.in/ahmetb/go-linq.v3"
import . 的意思是直接使用庫的方法,而不使用前綴。當(dāng)然你也可以添加,官方的寫法是這樣的。
定義一個(gè)員工類
type Employee struct { Name string Age int Sex int // 0 男 1 女 WorkYear int //工齡 }
創(chuàng)建不同的列表
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}]
結(jié)果非常nice,本來我們需要的繁瑣步驟,一個(gè)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 選取從頭開始的幾個(gè)元素 fmt.Println("===過濾性別是男的員工,只選擇前倆個(gè)===") 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)
//聚合函數(shù) 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())[]
//獲取結(jié)構(gòu)體數(shù)組首個(gè)元素或者末個(gè) firstItem := From(rows).First() fmt.Println(firstItem) lastItem := From(rows).Last() fmt.Println(lastItem)
到此,相信大家對(duì)“如何使用Go-Linq”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。