1
0
mirror of https://github.com/duke-git/lancet.git synced 2026-02-04 12:52:28 +08:00

docs: add doc for UnionBy and KeyBy

This commit is contained in:
dudaodong
2022-11-08 14:21:17 +08:00
parent 84da7d4f27
commit ee9e9625e2
2 changed files with 387 additions and 309 deletions

View File

@@ -1,16 +1,17 @@
# Slice
Package slice implements some functions to manipulate slice.
<div STYLE="page-break-after: always;"></div>
## Source:
- [https://github.com/duke-git/lancet/blob/main/slice/slice.go](https://github.com/duke-git/lancet/blob/main/slice/slice.go)
- [https://github.com/duke-git/lancet/blob/main/slice/slice.go](https://github.com/duke-git/lancet/blob/main/slice/slice.go)
<div STYLE="page-break-after: always;"></div>
## Usage:
```go
import (
"github.com/duke-git/lancet/v2/slice"
@@ -20,59 +21,63 @@ import (
<div STYLE="page-break-after: always;"></div>
## Index
- [AppendIfAbsent](#AppendIfAbsent)
- [Contain](#Contain)
- [ContainSubSlice](#ContainSubSlice)
- [Chunk](#Chunk)
- [Compact](#Compact)
- [Concat](#Concat)
- [Count](#Count)
- [Difference](#Difference)
- [DifferenceBy](#DifferenceBy)
- [DifferenceWith](#DifferenceWith)
- [DeleteAt](#DeleteAt)
- [Drop](#Drop)
- [Equal](#Equal)
- [EqualWith](#EqualWith)
- [Every](#Every)
- [Filter](#Filter)
- [Find](#Find)
- [FindLast](#FindLast)
- [Flatten](#Flatten)
- [FlattenDeep](#FlattenDeep)
- [ForEach](#ForEach)
- [GroupBy](#GroupBy)
- [GroupWith](#GroupWith)
- [IntSlice](#IntSlice)
- [InterfaceSlice](#InterfaceSlice)
- [Intersection](#Intersection)
- [InsertAt](#InsertAt)
- [IndexOf](#IndexOf)
- [LastIndexOf](#LastIndexOf)
- [Map](#Map)
- [Reverse](#Reverse)
- [Reduce](#Reduce)
- [Replace](#Replace)
- [ReplaceAll](#ReplaceAll)
- [Shuffle](#Shuffle)
- [SortByField](#SortByField)
- [Some](#Some)
- [StringSlice](#StringSlice)
- [SymmetricDifference](#SymmetricDifference)
- [ToSlice](#ToSlice)
- [ToSlicePointer](#ToSlicePointer)
- [Unique](#Unique)
- [UniqueBy](#UniqueBy)
- [Union](#Union)
- [UpdateAt](#UpdateAt)
- [Without](#Without)
- [AppendIfAbsent](#AppendIfAbsent)
- [Contain](#Contain)
- [ContainSubSlice](#ContainSubSlice)
- [Chunk](#Chunk)
- [Compact](#Compact)
- [Concat](#Concat)
- [Count](#Count)
- [Difference](#Difference)
- [DifferenceBy](#DifferenceBy)
- [DifferenceWith](#DifferenceWith)
- [DeleteAt](#DeleteAt)
- [Drop](#Drop)
- [Equal](#Equal)
- [EqualWith](#EqualWith)
- [Every](#Every)
- [Filter](#Filter)
- [Find](#Find)
- [FindLast](#FindLast)
- [Flatten](#Flatten)
- [FlattenDeep](#FlattenDeep)
- [ForEach](#ForEach)
- [GroupBy](#GroupBy)
- [GroupWith](#GroupWith)
- [IntSlice](#IntSlice)
- [InterfaceSlice](#InterfaceSlice)
- [Intersection](#Intersection)
- [InsertAt](#InsertAt)
- [IndexOf](#IndexOf)
- [LastIndexOf](#LastIndexOf)
- [Map](#Map)
- [Reverse](#Reverse)
- [Reduce](#Reduce)
- [Replace](#Replace)
- [ReplaceAll](#ReplaceAll)
- [Shuffle](#Shuffle)
- [SortByField](#SortByField)
- [Some](#Some)
- [StringSlice](#StringSlice)
- [SymmetricDifference](#SymmetricDifference)
- [ToSlice](#ToSlice)
- [ToSlicePointer](#ToSlicePointer)
- [Unique](#Unique)
- [UniqueBy](#UniqueBy)
- [Union](#Union)
- [UnionBy](#UnionBy)
- [UpdateAt](#UpdateAt)
- [Without](#Without)
- [KeyBy](#KeyBy)
<div STYLE="page-break-after: always;"></div>
## Documentation
### <span id="AppendIfAbsent">AppendIfAbsent</span>
<p>If slice doesn't contain the value, append it to the slice.</p>
<b>Signature:</b>
@@ -80,6 +85,7 @@ import (
```go
func AppendIfAbsent[T comparable](slice []T, value T) []T
```
<b>Example:</b>
```go
@@ -98,8 +104,8 @@ func main() {
}
```
### <span id="Contain">Contain</span>
<p>Check if the value is in the slice or not.</p>
<b>Signature:</b>
@@ -107,6 +113,7 @@ func main() {
```go
func Contain[T comparable](slice []T, value T) bool
```
<b>Example:</b>
```go
@@ -121,8 +128,8 @@ func main() {
}
```
### <span id="ContainSubSlice">ContainSubSlice</span>
<p>Check if the slice contain subslice or not.</p>
<b>Signature:</b>
@@ -130,6 +137,7 @@ func main() {
```go
func ContainSubSlice[T comparable](slice, subslice []T) bool
```
<b>Example:</b>
```go
@@ -144,10 +152,8 @@ func main() {
}
```
### <span id="Chunk">Chunk</span>
<p>Creates an slice of elements split into groups the length of `size`.</p>
<b>Signature:</b>
@@ -155,6 +161,7 @@ func main() {
```go
func Chunk[T any](slice []T, size int) [][]T
```
<b>Example:</b>
```go
@@ -170,9 +177,8 @@ func main() {
}
```
### <span id="Compact">Compact</span>
<p>Creates an slice with all falsey values removed. The values false, nil, 0, and "" are falsey.</p>
<b>Signature:</b>
@@ -180,6 +186,7 @@ func main() {
```go
func Compact[T any](slice []T) []T
```
<b>Example:</b>
```go
@@ -194,8 +201,8 @@ func main() {
}
```
### <span id="Concat">Concat</span>
<p>Creates a new slice concatenating slice with any additional slices and/or values.</p>
<b>Signature:</b>
@@ -203,6 +210,7 @@ func main() {
```go
func Concat[T any](slice []T, values ...[]T) []T
```
<b>Example:</b>
```go
@@ -220,9 +228,8 @@ func main() {
}
```
### <span id="Count">Count</span>
<p>Count iterates over elements of slice, returns a count of all matched elements.</p>
<b>Signature:</b>
@@ -230,6 +237,7 @@ func main() {
```go
func Count[T any](slice []T, predicate func(index int, t T) bool) int
```
<b>Example:</b>
```go
@@ -249,10 +257,8 @@ func main() {
}
```
### <span id="Difference">Difference</span>
<p>Creates an slice of whose element not included in the other given slice.</p>
<b>Signature:</b>
@@ -260,6 +266,7 @@ func main() {
```go
func Difference[T comparable](slice, comparedSlice []T) []T
```
<b>Example:</b>
```go
@@ -277,10 +284,8 @@ func main() {
}
```
### <span id="DifferenceBy">DifferenceBy</span>
<p>DifferenceBy accepts iteratee func which is invoked for each element of slice and values to generate the criterion by which they're compared.</p>
<b>Signature:</b>
@@ -288,6 +293,7 @@ func main() {
```go
func DifferenceBy[T comparable](slice []T, comparedSlice []T, iteratee func(index int, item T) T) []T
```
<b>Example:</b>
```go
@@ -308,8 +314,8 @@ func main() {
}
```
### <span id="DifferenceWith">DifferenceWith</span>
<p>DifferenceWith accepts comparator which is invoked to compare elements of slice to values. The order and references of result values are determined by the first slice.</p>
<b>Signature:</b>
@@ -317,6 +323,7 @@ func main() {
```go
func DifferenceWith[T any](slice []T, comparedSlice []T, comparator func(value, otherValue T) bool) []T
```
<b>Example:</b>
```go
@@ -338,6 +345,7 @@ func main() {
```
### <span id="DeleteAt">DeleteAt</span>
<p>Delete the element of slice from start index to end index - 1.</p>
<b>Signature:</b>
@@ -345,6 +353,7 @@ func main() {
```go
func DeleteAt[T any](slice []T, start int, end ...int)
```
<b>Example:</b>
```go
@@ -363,10 +372,8 @@ func main() {
}
```
### <span id="Drop">Drop</span>
<p>Creates a slice with `n` elements dropped from the beginning when n > 0, or `n` elements dropped from the ending when n < 0.</p>
<b>Signature:</b>
@@ -374,6 +381,7 @@ func main() {
```go
func Drop[T any](slice []T, n int) []T
```
<b>Example:</b>
```go
@@ -394,9 +402,8 @@ func main() {
}
```
### <span id="Equal">Equal</span>
<p>Check if two slices are equal: the same length and all elements' order and value are equal.</p>
<b>Signature:</b>
@@ -404,6 +411,7 @@ func main() {
```go
func Equal[T comparable](slice1, slice2 []T) bool
```
<b>Example:</b>
```go
@@ -425,9 +433,8 @@ func main() {
}
```
### <span id="EqualWith">EqualWith</span>
<p>Check if two slices are equal with comparator func.</p>
<b>Signature:</b>
@@ -435,6 +442,7 @@ func main() {
```go
func EqualWith[T, U any](slice1 []T, slice2 []U, comparator func(T, U) bool) bool
```
<b>Example:</b>
```go
@@ -457,9 +465,8 @@ func main() {
}
```
### <span id="Every">Every</span>
<p>Return true if all of the values in the slice pass the predicate function.</p>
<b>Signature:</b>
@@ -467,6 +474,7 @@ func main() {
```go
func Every[T any](slice []T, predicate func(index int, item T) bool) bool
```
<b>Example:</b>
```go
@@ -486,10 +494,8 @@ func main() {
}
```
### <span id="Filter">Filter</span>
<p>Return all elements which match the function.</p>
<b>Signature:</b>
@@ -497,6 +503,7 @@ func main() {
```go
func Filter[T any](slice []T, predicate func(index int, item T) bool) []T
```
<b>Example:</b>
```go
@@ -516,9 +523,8 @@ func main() {
}
```
### <span id="Find">Find</span>
<p>Iterates over elements of slice, returning the first one that passes a truth test on function.</p>
<b>Signature:</b>
@@ -526,6 +532,7 @@ func main() {
```go
func Find[T any](slice []T, predicate func(index int, item T) bool) (*T, bool)
```
<b>Example:</b>
```go
@@ -546,10 +553,8 @@ func main() {
}
```
### <span id="FindLast">FindLast</span>
<p>iterates over elements of slice from end to begin, returning the last one that passes a truth test on function.</p>
<b>Signature:</b>
@@ -557,6 +562,7 @@ func main() {
```go
func FindLast[T any](slice []T, predicate func(index int, item T) bool) (*T, bool)
```
<b>Example:</b>
```go
@@ -577,9 +583,8 @@ func main() {
}
```
### <span id="Flatten">Flatten</span>
<p>Flatten slice with one level.</p>
<b>Signature:</b>
@@ -587,6 +592,7 @@ func main() {
```go
func Flatten(slice any) any
```
<b>Example:</b>
```go
@@ -602,9 +608,8 @@ func main() {
}
```
### <span id="FlattenDeep">FlattenDeep</span>
<p>flattens slice recursive.</p>
<b>Signature:</b>
@@ -612,6 +617,7 @@ func main() {
```go
func FlattenDeep(slice any) any
```
<b>Example:</b>
```go
@@ -627,11 +633,8 @@ func main() {
}
```
### <span id="ForEach">ForEach</span>
<p>Iterates over elements of slice and invokes function for each element.</p>
<b>Signature:</b>
@@ -639,6 +642,7 @@ func main() {
```go
func ForEach[T any](slice []T, iteratee func(index int, item T))
```
<b>Example:</b>
```go
@@ -657,10 +661,8 @@ func main() {
}
```
### <span id="GroupBy">GroupBy</span>
<p>Iterates over elements of the slice, each element will be group by criteria, returns two slices.</p>
<b>Signature:</b>
@@ -668,6 +670,7 @@ func main() {
```go
func GroupBy[T any](slice []T, groupFn func(index int, item T) bool) ([]T, []T)
```
<b>Example:</b>
```go
@@ -688,17 +691,16 @@ func main() {
}
```
### <span id="GroupWith">GroupWith</span>
<p>Return a map composed of keys generated from the results of running each element of slice thru iteratee.</p>
<b>Signature:</b>
```go
func GroupWith[T any, U comparable](slice []T, iteratee func(T) U) map[U][]T
func GroupWith[T any, U comparable](slice []T, iteratee func(T) U) map[U][]T
```
<b>Example:</b>
```go
@@ -717,9 +719,8 @@ func main() {
}
```
### <span id="IntSlice">IntSlice</span>
<p>Convert interface slice to int slice.</p>
<b>Signature:</b>
@@ -727,6 +728,7 @@ func main() {
```go
func IntSlice(slice any) []int
```
<b>Example:</b>
```go
@@ -742,10 +744,8 @@ func main() {
}
```
### <span id="InterfaceSlice">InterfaceSlice</span>
<p>Convert value to interface slice.</p>
<b>Signature:</b>
@@ -753,6 +753,7 @@ func main() {
```go
func InterfaceSlice(slice any) []any
```
<b>Example:</b>
```go
@@ -768,10 +769,8 @@ func main() {
}
```
### <span id="Intersection">Intersection</span>
<p>Creates a slice of unique values that included by all slices.</p>
<b>Signature:</b>
@@ -779,6 +778,7 @@ func main() {
```go
func Intersection[T comparable](slices ...[]T) []T
```
<b>Example:</b>
```go
@@ -796,10 +796,8 @@ func main() {
}
```
### <span id="InsertAt">InsertAt</span>
<p>insert the element into slice at index.</p>
<b>Signature:</b>
@@ -807,6 +805,7 @@ func main() {
```go
func InsertAt[T any](slice []T, index int, value any) []T
```
<b>Example:</b>
```go
@@ -817,7 +816,7 @@ import (
func main() {
s := []string{"a", "b", "c"}
res1, _ := slice.InsertAt(s, 0, "1")
fmt.Println(res1) //[]string{"1", "a", "b", "c"}
@@ -826,10 +825,8 @@ func main() {
}
```
### <span id="IndexOf">IndexOf</span>
<p>Returns the index at which the first occurrence of a value is found in a slice or return -1 if the value cannot be found.</p>
<b>Signature:</b>
@@ -837,6 +834,7 @@ func main() {
```go
func IndexOf[T comparable](slice []T, value T) int
```
<b>Example:</b>
```go
@@ -855,9 +853,8 @@ func main() {
}
```
### <span id="LastIndexOf">LastIndexOf</span>
<p>Returns the index at which the last occurrence of a value is found in a slice or return -1 if the value cannot be found.</p>
<b>Signature:</b>
@@ -865,6 +862,7 @@ func main() {
```go
func LastIndexOf[T comparable](slice []T, value T) int
```
<b>Example:</b>
```go
@@ -883,10 +881,8 @@ func main() {
}
```
### <span id="Map">Map</span>
<p>Creates an slice of values by running each element in slice thru function.</p>
<b>Signature:</b>
@@ -894,6 +890,7 @@ func main() {
```go
func Map[T any, U any](slice []T, iteratee func(index int, item T) U) []U
```
<b>Example:</b>
```go
@@ -912,10 +909,8 @@ func main() {
}
```
### <span id="Reverse">Reverse</span>
<p>Reverse the elements order in slice.</p>
<b>Signature:</b>
@@ -923,6 +918,7 @@ func main() {
```go
func Reverse[T any](slice []T)
```
<b>Example:</b>
```go
@@ -938,9 +934,8 @@ func main() {
}
```
### <span id="Reduce">Reduce</span>
<p>Reduce slice.</p>
<b>Signature:</b>
@@ -948,6 +943,7 @@ func main() {
```go
func Reduce[T any](slice []T, iteratee func(index int, item1, item2 T) T, initial T) T
```
<b>Example:</b>
```go
@@ -966,9 +962,8 @@ func main() {
}
```
### <span id="Replace">Replace</span>
<p>Returns a copy of the slice with the first n non-overlapping instances of old replaced by new.</p>
<b>Signature:</b>
@@ -976,6 +971,7 @@ func main() {
```go
func Replace[T comparable](slice []T, old T, new T, n int) []T
```
<b>Example:</b>
```go
@@ -995,9 +991,8 @@ func main() {
}
```
### <span id="ReplaceAll">ReplaceAll</span>
<p>Returns a copy of the slice with the first n non-overlapping instances of old replaced by new.</p>
<b>Signature:</b>
@@ -1005,6 +1000,7 @@ func main() {
```go
func ReplaceAll[T comparable](slice []T, old T, new T) []T
```
<b>Example:</b>
```go
@@ -1022,8 +1018,8 @@ func main() {
}
```
### <span id="Shuffle">Shuffle</span>
<p>Creates an slice of shuffled values.</p>
<b>Signature:</b>
@@ -1031,6 +1027,7 @@ func main() {
```go
func Shuffle[T any](slice []T) []T
```
<b>Example:</b>
```go
@@ -1046,9 +1043,8 @@ func main() {
}
```
### <span id="SortByField">SortByField</span>
<p>Sort struct slice by field. Slice element should be struct, field type should be int, uint, string, or bool. Default sort type is ascending (asc), if descending order, set sortType to desc</p>
<b>Signature:</b>
@@ -1056,6 +1052,7 @@ func main() {
```go
func SortByField(slice any, field string, sortType ...string) error
```
<b>Example:</b>
```go
@@ -1079,7 +1076,7 @@ func main() {
if err != nil {
fmt.Println(err)
}
fmt.Println(students)
fmt.Println(students)
// []students{
// {"b", 15},
// {"a", 10},
@@ -1089,9 +1086,8 @@ func main() {
}
```
### <span id="Some">Some</span>
<p>Return true if any of the values in the list pass the predicate function.</p>
<b>Signature:</b>
@@ -1099,6 +1095,7 @@ func main() {
```go
func Some[T any](slice []T, predicate func(index int, item T) bool) bool
```
<b>Example:</b>
```go
@@ -1118,9 +1115,8 @@ func main() {
}
```
### <span id="StringSlice">StringSlice</span>
<p>Convert interface slice to string slice.</p>
<b>Signature:</b>
@@ -1128,6 +1124,7 @@ func main() {
```go
func StringSlice(slice any) []string
```
<b>Example:</b>
```go
@@ -1143,10 +1140,8 @@ func main() {
}
```
### <span id="SymmetricDifference">SymmetricDifference</span>
<p>Create a slice whose element is in given slices, but not in both slices.</p>
<b>Signature:</b>
@@ -1154,6 +1149,7 @@ func main() {
```go
func SymmetricDifference[T comparable](slices ...[]T) []T
```
<b>Example:</b>
```go
@@ -1173,9 +1169,8 @@ func main() {
}
```
### <span id="ToSlice">ToSlice</span>
<p>Returns a slices of a variable parameter transformation</p>
<b>Signature:</b>
@@ -1183,6 +1178,7 @@ func main() {
```go
func ToSlice[T any](value ...T) []T
```
<b>Example:</b>
```go
@@ -1197,9 +1193,8 @@ func main() {
}
```
### <span id="ToSlicePointer">ToSlicePointer</span>
<p>Returns a pointer to the slices of a variable parameter transformation</p>
<b>Signature:</b>
@@ -1207,6 +1202,7 @@ func main() {
```go
func ToSlicePointer[T any](value ...T) []*T
```
<b>Example:</b>
```go
@@ -1223,8 +1219,8 @@ func main() {
}
```
### <span id="Unique">Unique</span>
<p>Remove duplicate elements in slice.</p>
<b>Signature:</b>
@@ -1232,6 +1228,7 @@ func main() {
```go
func Unique[T comparable](slice []T) []T
```
<b>Example:</b>
```go
@@ -1246,9 +1243,8 @@ func main() {
}
```
### <span id="UniqueBy">UniqueBy</span>
<p>Call iteratee func with every item of slice, then remove duplicated.</p>
<b>Signature:</b>
@@ -1256,6 +1252,7 @@ func main() {
```go
func UniqueBy[T comparable](slice []T, iteratee func(item T) T) []T
```
<b>Example:</b>
```go
@@ -1272,9 +1269,8 @@ func main() {
}
```
### <span id="Union">Union</span>
<p>Creates a slice of unique values, in order, from all given slices. using == for equality comparisons.</p>
<b>Signature:</b>
@@ -1282,6 +1278,7 @@ func main() {
```go
func Union[T comparable](slices ...[]T) []T
```
<b>Example:</b>
```go
@@ -1299,9 +1296,35 @@ func main() {
}
```
### <span id="UnionBy">UnionBy</span>
<p>UnionBy is like Union, what's more it accepts iteratee which is invoked for each element of each slice.</p>
<b>Signature:</b>
```go
func UnionBy[T any, V comparable](predicate func(item T) V, slices ...[]T) []T
```
<b>Example:</b>
```go
import (
"fmt"
"github.com/duke-git/lancet/v2/slice"
)
func main() {
testFunc := func(i int) int {
return i / 2
}
result := slice.UnionBy(testFunc, []int{0, 1, 2, 3, 4, 5}, []int{0, 2, 10})
fmt.Println(result) //[]int{0, 2, 4, 10}
}
```
### <span id="UpdateAt">UpdateAt</span>
<p>Update the slice element at index. if param index < 0 or index >= len(slice), will return error. </p>
<b>Signature:</b>
@@ -1309,6 +1332,7 @@ func main() {
```go
func UpdateAt[T any](slice []T, index int, value T) []T
```
<b>Example:</b>
```go
@@ -1319,16 +1343,14 @@ import (
func main() {
s := []string{"a", "b", "c"}
res1, _ := slice.UpdateAt(s, 0, "1")
fmt.Println(res1) //[]string{"1", "b", "c"}
}
```
### <span id="Without">Without</span>
<p>Creates a slice excluding all given values. </p>
<b>Signature:</b>
@@ -1336,6 +1358,7 @@ func main() {
```go
func Without[T comparable](slice []T, values ...T) []T
```
<b>Example:</b>
```go
@@ -1350,13 +1373,29 @@ func main() {
}
```
### <span id="KeyBy">KeyBy</span>
<p>Converts a slice to a map based on a callback function.</p>
<b>Signature:</b>
```go
func KeyBy[T any, U comparable](slice []T, iteratee func(item T) U) map[U]T
```
<b>Example:</b>
```go
import (
"fmt"
"github.com/duke-git/lancet/v2/slice"
)
func main() {
res := slice.KeyBy([]string{"a", "ab", "abc"}, func(str string) int {
return len(str)
})
fmt.Println(res) //map[int]string{1: "a", 2: "ab", 3: "abc"}
}
```

View File

@@ -1,16 +1,17 @@
# Slice
slice包包含操作切片的方法集合。
slice 包包含操作切片的方法集合。
<div STYLE="page-break-after: always;"></div>
## 源码:
- [https://github.com/duke-git/lancet/blob/main/slice/slice.go](https://github.com/duke-git/lancet/blob/main/slice/slice.go)
- [https://github.com/duke-git/lancet/blob/main/slice/slice.go](https://github.com/duke-git/lancet/blob/main/slice/slice.go)
<div STYLE="page-break-after: always;"></div>
## 用法:
```go
import (
"github.com/duke-git/lancet/v2/slice"
@@ -20,59 +21,63 @@ import (
<div STYLE="page-break-after: always;"></div>
## 目录
- [AppendIfAbsent](#AppendIfAbsent)
- [Contain](#Contain)
- [ContainSubSlice](#ContainSubSlice)
- [Chunk](#Chunk)
- [Compact](#Compact)
- [Concat](#Concat)
- [Count](#Count)
- [Difference](#Difference)
- [DifferenceBy](#DifferenceBy)
- [DifferenceWith](#DifferenceWith)
- [DeleteAt](#DeleteAt)
- [Drop](#Drop)
- [Every](#Every)
- [Equal](#Equal)
- [EqualWith](#EqualWith)
- [Filter](#Filter)
- [Find](#Find)
- [FindLast](#FindLast)
- [Flatten](#Flatten)
- [FlattenDeep](#FlattenDeep)
- [ForEach](#ForEach)
- [GroupBy](#GroupBy)
- [GroupWith](#GroupWith)
- [IntSlice](#IntSlice)
- [InterfaceSlice](#InterfaceSlice)
- [Intersection](#Intersection)
- [InsertAt](#InsertAt)
- [IndexOf](#IndexOf)
- [LastIndexOf](#LastIndexOf)
- [Map](#Map)
- [Reverse](#Reverse)
- [Reduce](#Reduce)
- [Replace](#Replace)
- [ReplaceAll](#ReplaceAll)
- [Shuffle](#Shuffle)
- [SortByField](#SortByField)
- [Some](#Some)
- [StringSlice](#StringSlice)
- [SymmetricDifference](#SymmetricDifference)
- [ToSlice](#ToSlice)
- [ToSlicePointer](#ToSlicePointer)
- [Unique](#Unique)
- [UniqueBy](#UniqueBy)
- [Union](#Union)
- [UpdateAt](#UpdateAt)
- [Without](#Without)
- [AppendIfAbsent](#AppendIfAbsent)
- [Contain](#Contain)
- [ContainSubSlice](#ContainSubSlice)
- [Chunk](#Chunk)
- [Compact](#Compact)
- [Concat](#Concat)
- [Count](#Count)
- [Difference](#Difference)
- [DifferenceBy](#DifferenceBy)
- [DifferenceWith](#DifferenceWith)
- [DeleteAt](#DeleteAt)
- [Drop](#Drop)
- [Every](#Every)
- [Equal](#Equal)
- [EqualWith](#EqualWith)
- [Filter](#Filter)
- [Find](#Find)
- [FindLast](#FindLast)
- [Flatten](#Flatten)
- [FlattenDeep](#FlattenDeep)
- [ForEach](#ForEach)
- [GroupBy](#GroupBy)
- [GroupWith](#GroupWith)
- [IntSlice](#IntSlice)
- [InterfaceSlice](#InterfaceSlice)
- [Intersection](#Intersection)
- [InsertAt](#InsertAt)
- [IndexOf](#IndexOf)
- [LastIndexOf](#LastIndexOf)
- [Map](#Map)
- [Reverse](#Reverse)
- [Reduce](#Reduce)
- [Replace](#Replace)
- [ReplaceAll](#ReplaceAll)
- [Shuffle](#Shuffle)
- [SortByField](#SortByField)
- [Some](#Some)
- [StringSlice](#StringSlice)
- [SymmetricDifference](#SymmetricDifference)
- [ToSlice](#ToSlice)
- [ToSlicePointer](#ToSlicePointer)
- [Unique](#Unique)
- [UniqueBy](#UniqueBy)
- [Union](#Union)
- [UnionBy](#UnionBy)
- [UpdateAt](#UpdateAt)
- [Without](#Without)
- [KeyBy](#KeyBy)
<div STYLE="page-break-after: always;"></div>
## 文档
### <span id="AppendIfAbsent">AppendIfAbsent</span>
<p>当前切片中不包含值时,将该值追加到切片中</p>
<b>函数签名:</b>
@@ -80,6 +85,7 @@ import (
```go
func AppendIfAbsent[T comparable](slice []T, value T) []T
```
<b>例子:</b>
```go
@@ -98,9 +104,8 @@ func main() {
}
```
### <span id="Contain">Contain</span>
<p>判断slice是否包含value</p>
<b>函数签名:</b>
@@ -108,6 +113,7 @@ func main() {
```go
func Contain[T comparable](slice []T, value T) bool
```
<b>例子:</b>
```go
@@ -122,8 +128,8 @@ func main() {
}
```
### <span id="ContainSubSlice">ContainSubSlice</span>
<p>判断slice是否包含subslice</p>
<b>函数签名:</b>
@@ -131,6 +137,7 @@ func main() {
```go
func ContainSubSlice[T comparable](slice, subslice []T) bool
```
<b>例子:</b>
```go
@@ -145,10 +152,8 @@ func main() {
}
```
### <span id="Chunk">Chunk</span>
<p>按照size参数均分slice</p>
<b>函数签名:</b>
@@ -156,6 +161,7 @@ func main() {
```go
func Chunk[T any](slice []T, size int) [][]T
```
<b>例子:</b>
```go
@@ -171,9 +177,8 @@ func main() {
}
```
### <span id="Compact">Compact</span>
<p>去除slice中的假值false values are false, nil, 0, ""</p>
<b>函数签名:</b>
@@ -181,6 +186,7 @@ func main() {
```go
func Compact[T any](slice []T) []T
```
<b>例子:</b>
```go
@@ -195,8 +201,8 @@ func main() {
}
```
### <span id="Concat">Concat</span>
<p>连接values到slice中values类型可以是切片或多个值</p>
<b>函数签名:</b>
@@ -204,6 +210,7 @@ func main() {
```go
func Concat[T any](slice []T, values ...[]T) []T
```
<b>例子:</b>
```go
@@ -221,9 +228,8 @@ func main() {
}
```
### <span id="Count">Count</span>
<p>遍历切片对每个元素执行函数function. 返回符合函数返回值为true的元素的个数</p>
<b>函数签名:</b>
@@ -231,6 +237,7 @@ func main() {
```go
func Count[T any](slice []T, predicate func(index int, t T) bool) int
```
<b>例子:</b>
```go
@@ -250,10 +257,8 @@ func main() {
}
```
### <span id="Difference">Difference</span>
<p>创建一个切片,其元素不包含在另一个给定切片中</p>
<b>函数签名:</b>
@@ -261,6 +266,7 @@ func main() {
```go
func Difference[T comparable](slice, comparedSlice []T) []T
```
<b>例子:</b>
```go
@@ -278,10 +284,8 @@ func main() {
}
```
### <span id="DifferenceBy">DifferenceBy</span>
<p>在slice和comparedSlice中的每个元素调用iteratee函数并比较它们的返回值如果不想等返回在slice中对应的值</p>
<b>函数签名:</b>
@@ -289,6 +293,7 @@ func main() {
```go
func DifferenceBy[T comparable](slice []T, comparedSlice []T, iteratee func(index int, item T) T) []T
```
<b>例子:</b>
```go
@@ -309,9 +314,8 @@ func main() {
}
```
### <span id="DifferenceWith">DifferenceWith</span>
<p>DifferenceWith 接受比较器,该比较器被调用以将切片的元素与值进行比较。 结果值的顺序和引用由第一个切片确定</p>
<b>函数签名:</b>
@@ -319,6 +323,7 @@ func main() {
```go
func DifferenceWith[T any](slice []T, comparedSlice []T, comparator func(value, otherValue T) bool) []T
```
<b>例子:</b>
```go
@@ -339,8 +344,8 @@ func main() {
}
```
### <span id="DeleteAt">DeleteAt</span>
<p>删除切片中从开始索引到结束索引-1的元素</p>
<b>函数签名:</b>
@@ -348,6 +353,7 @@ func main() {
```go
func DeleteAt[T any](slice []T, start int, end ...int)
```
<b>例子:</b>
```go
@@ -366,10 +372,8 @@ func main() {
}
```
### <span id="Drop">Drop</span>
<p>创建一个切片,当 n > 0 时从开头删除 n 个元素,或者当 n < 0 时从结尾删除 n 个元素</p>
<b>函数签名:</b>
@@ -377,6 +381,7 @@ func main() {
```go
func Drop[T any](slice []T, n int) []T
```
<b>例子:</b>
```go
@@ -397,10 +402,8 @@ func main() {
}
```
### <span id="Every">Every</span>
<p>如果切片中的所有值都通过谓词函数则返回true。 函数签名应该是func(index int, value any) bool</p>
<b>函数签名:</b>
@@ -408,6 +411,7 @@ func main() {
```go
func Every[T any](slice []T, predicate func(index int, item T) bool) bool
```
<b>例子:</b>
```go
@@ -427,10 +431,8 @@ func main() {
}
```
### <span id="Equal">Equal</span>
<p>检查两个切片是否相等,相等条件:切片长度相同,元素顺序和值都相同</p>
<b>函数签名:</b>
@@ -438,6 +440,7 @@ func main() {
```go
func Equal[T comparable](slice1, slice2 []T) bool
```
<b>例子:</b>
```go
@@ -459,9 +462,8 @@ func main() {
}
```
### <span id="EqualWith">EqualWith</span>
<p>检查两个切片是否相等相等条件对两个切片的元素调用比较函数comparator返回true</p>
<b>函数签名:</b>
@@ -469,6 +471,7 @@ func main() {
```go
func EqualWith[T, U any](slice1 []T, slice2 []U, comparator func(T, U) bool) bool
```
<b>例子:</b>
```go
@@ -491,9 +494,8 @@ func main() {
}
```
### <span id="Filter">Filter</span>
<p>返回切片中通过predicate函数真值测试的所有元素</p>
<b>函数签名:</b>
@@ -501,6 +503,7 @@ func main() {
```go
func Filter[T any](slice []T, predicate func(index int, item T) bool) []T
```
<b>例子:</b>
```go
@@ -520,9 +523,8 @@ func main() {
}
```
### <span id="Find">Find</span>
<p>遍历切片的元素返回第一个通过predicate函数真值测试的元素</p>
<b>函数签名:</b>
@@ -530,6 +532,7 @@ func main() {
```go
func Find[T any](slice []T, predicate func(index int, item T) bool) (*T, bool)
```
<b>例子:</b>
```go
@@ -550,10 +553,8 @@ func main() {
}
```
### <span id="FindLast">FindLast</span>
<p>从头到尾遍历slice的元素返回最后一个通过predicate函数真值测试的元素。</p>
<b>函数签名:</b>
@@ -561,6 +562,7 @@ func main() {
```go
func FindLast[T any](slice []T, predicate func(index int, item T) bool) (*T, bool)
```
<b>例子:</b>
```go
@@ -581,8 +583,8 @@ func main() {
}
```
### <span id="Flatten">Flatten</span>
<p>将切片压平一层</p>
<b>函数签名:</b>
@@ -590,6 +592,7 @@ func main() {
```go
func Flatten(slice any) any
```
<b>例子:</b>
```go
@@ -605,9 +608,8 @@ func main() {
}
```
### <span id="FlattenDeep">FlattenDeep</span>
<p>flattens slice recursive.</p>
<b>函数签名:</b>
@@ -615,6 +617,7 @@ func main() {
```go
func FlattenDeep(slice any) any
```
<b>例子:</b>
```go
@@ -630,11 +633,8 @@ func main() {
}
```
### <span id="ForEach">ForEach</span>
<p>遍历切片的元素并为每个元素调用iteratee函数</p>
<b>函数签名:</b>
@@ -642,6 +642,7 @@ func main() {
```go
func ForEach[T any](slice []T, iteratee func(index int, item T))
```
<b>例子:</b>
```go
@@ -660,10 +661,8 @@ func main() {
}
```
### <span id="GroupBy">GroupBy</span>
<p>迭代切片的元素,每个元素将按条件分组,返回两个切片</p>
<b>函数签名:</b>
@@ -671,6 +670,7 @@ func main() {
```go
func GroupBy[T any](slice []T, groupFn func(index int, item T) bool) ([]T, []T)
```
<b>例子:</b>
```go
@@ -691,16 +691,16 @@ func main() {
}
```
### <span id="GroupWith">GroupWith</span>
<p>创建一个mapkey是iteratee遍历slice中的每个元素返回的结果。 分组值的顺序是由他们出现在slice中的顺序确定的。每个键对应的值负责生成key的元素组成的数组。iteratee调用1个参数 (value)</p>
<b>函数签名:</b>
```go
func GroupWith[T any, U comparable](slice []T, iteratee func(T) U) map[U][]T
func GroupWith[T any, U comparable](slice []T, iteratee func(T) U) map[U][]T
```
<b>例子:</b>
```go
@@ -719,8 +719,8 @@ func main() {
}
```
### <span id="IntSlice">IntSlice</span>
<p>将接口切片转换为int切片</p>
<b>函数签名:</b>
@@ -728,6 +728,7 @@ func main() {
```go
func IntSlice(slice any) []int
```
<b>例子:</b>
```go
@@ -743,10 +744,8 @@ func main() {
}
```
### <span id="InterfaceSlice">InterfaceSlice</span>
<p>将值转换为接口切片</p>
<b>函数签名:</b>
@@ -754,6 +753,7 @@ func main() {
```go
func InterfaceSlice(slice any) []any
```
<b>例子:</b>
```go
@@ -769,10 +769,8 @@ func main() {
}
```
### <span id="Intersection">Intersection</span>
<p>多个切片的交集</p>
<b>函数签名:</b>
@@ -780,6 +778,7 @@ func main() {
```go
func Intersection[T comparable](slices ...[]T) []T
```
<b>例子:</b>
```go
@@ -797,10 +796,8 @@ func main() {
}
```
### <span id="InsertAt">InsertAt</span>
<p>将元素插入到索引处的切片中</p>
<b>函数签名:</b>
@@ -808,6 +805,7 @@ func main() {
```go
func InsertAt[T any](slice []T, index int, value any) []T
```
<b>例子:</b>
```go
@@ -818,7 +816,7 @@ import (
func main() {
s := []string{"a", "b", "c"}
res1, _ := slice.InsertAt(s, 0, "1")
fmt.Println(res1) //[]string{"1", "a", "b", "c"}
@@ -827,10 +825,8 @@ func main() {
}
```
### <span id="IndexOf">IndexOf</span>
<p>返回在切片中找到值的第一个匹配项的索引,如果找不到值,则返回-1</p>
<b>函数签名:</b>
@@ -838,6 +834,7 @@ func main() {
```go
func IndexOf[T comparable](slice []T, value T) int
```
<b>例子:</b>
```go
@@ -856,9 +853,8 @@ func main() {
}
```
### <span id="LastIndexOf">LastIndexOf</span>
<p>返回在切片中找到最后一个值的索引,如果找不到该值,则返回-1</p>
<b>函数签名:</b>
@@ -866,6 +862,7 @@ func main() {
```go
func LastIndexOf[T comparable](slice []T, value T) int
```
<b>例子:</b>
```go
@@ -884,9 +881,8 @@ func main() {
}
```
### <span id="Map">Map</span>
<p>通过运行函数slice中的每个元素来创建一个新切片</p>
<b>函数签名:</b>
@@ -894,6 +890,7 @@ func main() {
```go
func Map[T any, U any](slice []T, iteratee func(index int, item T) U) []U
```
<b>例子:</b>
```go
@@ -912,10 +909,8 @@ func main() {
}
```
### <span id="Reverse">Reverse</span>
<p>反转切片中的元素顺序</p>
<b>函数签名:</b>
@@ -923,6 +918,7 @@ func main() {
```go
func Reverse[T any](slice []T)
```
<b>例子:</b>
```go
@@ -938,9 +934,8 @@ func main() {
}
```
### <span id="Reduce">Reduce</span>
<p>将切片中的元素依次运行iteratee函数返回运行结果</p>
<b>函数签名:</b>
@@ -948,6 +943,7 @@ func main() {
```go
func Reduce[T any](slice []T, iteratee func(index int, item1, item2 T) T, initial T) T
```
<b>例子:</b>
```go
@@ -966,9 +962,8 @@ func main() {
}
```
### <span id="Replace">Replace</span>
<p>返回切片的副本其中前n个不重叠的old替换为new</p>
<b>函数签名:</b>
@@ -976,6 +971,7 @@ func main() {
```go
func Replace[T comparable](slice []T, old T, new T, n int) []T
```
<b>例子:</b>
```go
@@ -995,9 +991,8 @@ func main() {
}
```
### <span id="ReplaceAll">ReplaceAll</span>
<p>返回切片的副本将其中old全部替换为new</p>
<b>函数签名:</b>
@@ -1005,6 +1000,7 @@ func main() {
```go
func ReplaceAll[T comparable](slice []T, old T, new T) []T
```
<b>例子:</b>
```go
@@ -1022,9 +1018,8 @@ func main() {
}
```
### <span id="Shuffle">Shuffle</span>
<p>随机打乱切片中的元素顺序</p>
<b>函数签名:</b>
@@ -1032,6 +1027,7 @@ func main() {
```go
func Shuffle[T any](slice []T) []T
```
<b>例子:</b>
```go
@@ -1047,9 +1043,8 @@ func main() {
}
```
### <span id="SortByField">SortByField</span>
<p>按字段对结构切片进行排序。slice元素应为struct字段类型应为int、uint、string或bool。 默认排序类型是升序asc如果是降序设置 sortType 为 desc</p>
<b>函数签名:</b>
@@ -1057,6 +1052,7 @@ func main() {
```go
func SortByField(slice any, field string, sortType ...string) error
```
<b>例子:</b>
```go
@@ -1080,7 +1076,7 @@ func main() {
if err != nil {
fmt.Println(err)
}
fmt.Println(students)
fmt.Println(students)
// []students{
// {"b", 15},
// {"a", 10},
@@ -1090,9 +1086,8 @@ func main() {
}
```
### <span id="Some">Some</span>
<p>如果列表中的任何值通过谓词函数则返回true</p>
<b>函数签名:</b>
@@ -1100,6 +1095,7 @@ func main() {
```go
func Some[T any](slice []T, predicate func(index int, item T) bool) bool
```
<b>例子:</b>
```go
@@ -1119,9 +1115,8 @@ func main() {
}
```
### <span id="StringSlice">StringSlice</span>
<p>将接口切片转换为字符串切片</p>
<b>函数签名:</b>
@@ -1129,6 +1124,7 @@ func main() {
```go
func StringSlice(slice any) []string
```
<b>例子:</b>
```go
@@ -1144,10 +1140,8 @@ func main() {
}
```
### <span id="SymmetricDifference">SymmetricDifference</span>
<p>返回一个切片,其中的元素存在于参数切片中,但不同时存储在于参数切片中(交集取反)</p>
<b>函数签名:</b>
@@ -1155,6 +1149,7 @@ func main() {
```go
func SymmetricDifference[T comparable](slices ...[]T) []T
```
<b>例子:</b>
```go
@@ -1174,8 +1169,8 @@ func main() {
}
```
### <span id="ToSlice">ToSlice</span>
<p>将可变参数转为切片</p>
<b>函数签名:</b>
@@ -1183,6 +1178,7 @@ func main() {
```go
func ToSlice[T any](value ...T) []T
```
<b>例子:</b>
```go
@@ -1197,9 +1193,8 @@ func main() {
}
```
### <span id="ToSlicePointer">ToSlicePointer</span>
<p>将可变参数转为指针切片</p>
<b>函数签名:</b>
@@ -1207,6 +1202,7 @@ func main() {
```go
func ToSlicePointer[T any](value ...T) []*T
```
<b>例子:</b>
```go
@@ -1223,9 +1219,8 @@ func main() {
}
```
### <span id="Unique">Unique</span>
<p>删除切片中的重复元素</p>
<b>函数签名:</b>
@@ -1233,6 +1228,7 @@ func main() {
```go
func Unique[T comparable](slice []T) []T
```
<b>例子:</b>
```go
@@ -1247,9 +1243,8 @@ func main() {
}
```
### <span id="UniqueBy">UniqueBy</span>
<p>对切片的每个元素调用iteratee函数然后删除重复元素</p>
<b>函数签名:</b>
@@ -1257,6 +1252,7 @@ func main() {
```go
func UniqueBy[T comparable](slice []T, iteratee func(item T) T) []T
```
<b>例子:</b>
```go
@@ -1273,16 +1269,16 @@ func main() {
}
```
### <span id="Union">Union</span>
<p>从所有给定的切片按顺序创建一个唯一值切片,使用==进行相等比较</p>
<p>合并多个切片.</p>
<b>函数签名:</b>
```go
func Union[T comparable](slices ...[]T) []T
```
<b>例子:</b>
```go
@@ -1300,9 +1296,35 @@ func main() {
}
```
### <span id="UnionBy">UnionBy</span>
<p>对切片的每个元素调用函数后,合并多个切片</p>
<b>函数签名:</b>
```go
func UnionBy[T any, V comparable](predicate func(item T) V, slices ...[]T) []T
```
<b>例子:</b>
```go
import (
"fmt"
"github.com/duke-git/lancet/v2/slice"
)
func main() {
testFunc := func(i int) int {
return i / 2
}
result := slice.UnionBy(testFunc, []int{0, 1, 2, 3, 4, 5}, []int{0, 2, 10})
fmt.Println(result) //[]int{0, 2, 4, 10}
}
```
### <span id="UpdateAt">UpdateAt</span>
<p>更新索引处的切片元素。 如果index < 0或 index >= len(slice),将返回错误</p>
<b>函数签名:</b>
@@ -1310,6 +1332,7 @@ func main() {
```go
func UpdateAt[T any](slice []T, index int, value T) []T
```
<b>例子:</b>
```go
@@ -1320,16 +1343,14 @@ import (
func main() {
s := []string{"a", "b", "c"}
res1, _ := slice.UpdateAt(s, 0, "1")
fmt.Println(res1) //[]string{"1", "b", "c"}
}
```
### <span id="Without">Without</span>
<p>创建一个不包括所有给定值的切片</p>
<b>函数签名:</b>
@@ -1337,6 +1358,7 @@ func main() {
```go
func Without[T comparable](slice []T, values ...T) []T
```
<b>例子:</b>
```go
@@ -1352,12 +1374,29 @@ func main() {
```
### <span id="KeyBy">KeyBy</span>
<p>将切片每个元素调用函数后转为map</p>
<b>函数签名:</b>
```go
func KeyBy[T any, U comparable](slice []T, iteratee func(item T) U) map[U]T
```
<b>例子:</b>
```go
import (
"fmt"
"github.com/duke-git/lancet/v2/slice"
)
func main() {
res := slice.KeyBy([]string{"a", "ab", "abc"}, func(str string) int {
return len(str)
})
fmt.Println(res) //map[int]string{1: "a", 2: "ab", 3: "abc"}
}
```