91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用Go-Linq

發布時間:2021-10-18 11:17:52 來源:億速云 閱讀:246 作者:iii 欄目:編程語言

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

坑爹的集合

go在進行集合操作時,有很不舒服的地方,起初我真的是無力吐槽,又苦于找不到一個好的第三方庫,只能每次寫著重復代碼。舉個栗子

類 學生{
姓名 
年齡
性別
}

1、現在有10個學生的數組,如果我要統計所有年齡大于20歲的人,那我需要

一、遍歷

二、自定義條件

三、再append數組添加。

2、接著我又要統計性別為男的所有學生,我又要重復上面的步驟。

你說坑爹不坑爹,那是真的坑!

吐槽之處

重點是95%的代碼都是一樣的,只是那百分之幾有點區別。對于一名合格的程序員,我是堅決不能忍受這種情況的發生。

解決方法

群里尋求大神幫助

混跡各大論壇,博客尋找有效信息

終于在老夫的不懈努力下,發現了一個庫。它就是go-linq,使用它,能夠解決我對集合大部分的需求,讓編程更順手,讓工作更強經勁。

什么是Linq呢?

LINQ(發音:Link)是語言級集成查詢(Language INtegrated Query)

?LINQ是一種用來進行數據訪問的編程模型,使得.NET語言可以直接支持數據查詢

Linq 是C#編程的一個爽的飛起的語法糖,使用過的人無一不對其高級的特性,偏自然語義化的折服。

那么問題來了

那么問題來了,go有沒有類似的東西呢,答案是肯定的,這次是我們馬上要說的庫Go-linq。通過這名稱你就知道他是做什么的了。不多說了,直接開Lu。

開始使用Go-Linq

Go-Linq介紹

一個強大的語言集成查詢(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
}

小試牛刀-distinct去除開始

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過濾

//where 過濾條件
var manEmpRows []Employee
fmt.Println("===過濾性別是男的員工===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 0
}).ToSlice(&manEmpRows)
fmt.Println(manEmpRows)

榮獲三甲-take+sort

//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)

弱水三千 只取一瓢-Select

//只獲取元素中的某些字段,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”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

行唐县| 孝昌县| 如东县| 金阳县| 普宁市| 古田县| 盐池县| 西乌珠穆沁旗| 噶尔县| 秦皇岛市| 西昌市| 舒城县| 沈阳市| 青海省| 遵义市| 山东省| 沽源县| 瓮安县| 谷城县| 龙胜| 兴宁市| 龙江县| 正阳县| 文成县| 临桂县| 邯郸县| 胶州市| 江津市| 阿瓦提县| 高邮市| 连云港市| 马关县| 平远县| 增城市| 新兴县| 长汀县| 涡阳县| 伊通| 福贡县| 汉中市| 从化市|