本篇內(nèi)容主要講解“如何使用Go-Linq”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何使用Go-Linq”吧!

創(chuàng)新互聯(lián)建站成立十多年來,這條路我們正越走越好,積累了技術(shù)與客戶資源,形成了良好的口碑。為客戶提供網(wǎng)站設(shè)計制作、做網(wǎng)站、網(wǎng)站策劃、網(wǎng)頁設(shè)計、主機域名、網(wǎng)絡(luò)營銷、VI設(shè)計、網(wǎng)站改版、漏洞修補等服務(wù)。網(wǎng)站是否美觀、功能強大、用戶體驗好、性價比高、打開快等等,這些對于網(wǎng)站建設(shè)都非常重要,創(chuàng)新互聯(lián)建站通過對建站技術(shù)性的掌握、對創(chuàng)意設(shè)計的研究為客戶提供一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶,共同發(fā)展進步。
go在進行集合操作時,有很不舒服的地方,起初我真的是無力吐槽,又苦于找不到一個好的第三方庫,只能每次寫著重復代碼。舉個栗子
類 學生{
姓名
年齡
性別
}1、現(xiàn)在有10個學生的數(shù)組,如果我要統(tǒng)計所有年齡大于20歲的人,那我需要
一、遍歷
二、自定義條件
三、再append數(shù)組添加。
2、接著我又要統(tǒng)計性別為男的所有學生,我又要重復上面的步驟。
你說坑爹不坑爹,那是真的坑!
重點是95%的代碼都是一樣的,只是那百分之幾有點區(qū)別。對于一名合格的程序員,我是堅決不能忍受這種情況的發(fā)生。
群里尋求大神幫助
混跡各大論壇,博客尋找有效信息
終于在老夫的不懈努力下,發(fā)現(xiàn)了一個庫。它就是go-linq,使用它,能夠解決我對集合大部分的需求,讓編程更順手,讓工作更強經(jīng)勁。
LINQ(發(fā)音:Link)是語言級集成查詢(Language INtegrated Query)
?LINQ是一種用來進行數(shù)據(jù)訪問的編程模型,使得.NET語言可以直接支持數(shù)據(jù)查詢
Linq 是C#編程的一個爽的飛起的語法糖,使用過的人無一不對其高級的特性,偏自然語義化的折服。
那么問題來了,go有沒有類似的東西呢,答案是肯定的,這次是我們馬上要說的庫Go-linq。通過這名稱你就知道他是做什么的了。不多說了,直接開Lu。
一個強大的語言集成查詢(LINQ)庫的Go。
沒有依賴!
使用迭代器模式完成延遲求值
對并發(fā)使用是安全的
支持泛型函數(shù),使您的代碼更干凈,并且沒有類型斷言
支持數(shù)組、片、映射、字符串、通道和自定義集合
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 //工齡
}創(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,本來我們需要的繁瑣步驟,一個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)//聚合函數(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ù)組首個元素或者末個 firstItem := From(rows).First() fmt.Println(firstItem) lastItem := From(rows).Last() fmt.Println(lastItem)
到此,相信大家對“如何使用Go-Linq”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!
當前文章:如何使用Go-Linq
當前地址:http://chinadenli.net/article24/iigpce.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、移動網(wǎng)站建設(shè)、建站公司、動態(tài)網(wǎng)站、服務(wù)器托管、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)