mirror of
https://github.com/duke-git/lancet.git
synced 2026-03-01 00:35:28 +08:00
Compare commits
4 Commits
6e5b67bee7
...
v2.2.8
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
c5297ec329 | ||
|
|
aa4b61ff85 | ||
|
|
7dbd7002a3 | ||
|
|
a995db445a |
10
README.md
10
README.md
@@ -4,7 +4,7 @@
|
|||||||
<br/>
|
<br/>
|
||||||
|
|
||||||

|

|
||||||
[](https://github.com/duke-git/lancet/releases)
|
[](https://github.com/duke-git/lancet/releases)
|
||||||
[](https://pkg.go.dev/github.com/duke-git/lancet/v2)
|
[](https://pkg.go.dev/github.com/duke-git/lancet/v2)
|
||||||
[](https://goreportcard.com/report/github.com/duke-git/lancet/v2)
|
[](https://goreportcard.com/report/github.com/duke-git/lancet/v2)
|
||||||
[](https://github.com/duke-git/lancet/actions/workflows/codecov.yml)
|
[](https://github.com/duke-git/lancet/actions/workflows/codecov.yml)
|
||||||
@@ -1097,6 +1097,12 @@ import "github.com/duke-git/lancet/v2/random"
|
|||||||
- **<big>RandUniqueIntSlice</big>** : generate a slice of random int of length n that do not repeat.
|
- **<big>RandUniqueIntSlice</big>** : generate a slice of random int of length n that do not repeat.
|
||||||
[[doc](https://github.com/duke-git/lancet/blob/main/docs/en/api/packages/random.md#RandUniqueIntSlice)]
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/en/api/packages/random.md#RandUniqueIntSlice)]
|
||||||
[[play](https://go.dev/play/p/uBkRSOz73Ec)]
|
[[play](https://go.dev/play/p/uBkRSOz73Ec)]
|
||||||
|
- **<big>RandSymbolChar</big>** : Generate a random symbol char of specified length.
|
||||||
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/en/api/packages/random.md#RandSymbolChar)]
|
||||||
|
- **<big>RandFloat</big>** : Generate a random float64 number between [min, max) with specific precision.
|
||||||
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/en/api/packages/random.md#RandFloat)]
|
||||||
|
- **<big>RandFloats</big>** : Generate a slice of random float64 numbers of length n that do not repeat.
|
||||||
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/en/api/packages/random.md#RandFloats)]
|
||||||
|
|
||||||
<h3 id="retry"> 17. Retry package is for executing a function repeatedly until it was successful or canceled by the context. <a href="#index">index</a></h3>
|
<h3 id="retry"> 17. Retry package is for executing a function repeatedly until it was successful or canceled by the context. <a href="#index">index</a></h3>
|
||||||
|
|
||||||
@@ -1340,6 +1346,8 @@ import "github.com/duke-git/lancet/v2/slice"
|
|||||||
- **<big>Partition</big>** : partition all slice elements with the evaluation of the given predicate functions.
|
- **<big>Partition</big>** : partition all slice elements with the evaluation of the given predicate functions.
|
||||||
[[doc](https://github.com/duke-git/lancet/blob/main/docs/en/api/packages/slice.md#Partition)]
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/en/api/packages/slice.md#Partition)]
|
||||||
[[play](https://go.dev/play/p/lkQ3Ri2NQhV)]
|
[[play](https://go.dev/play/p/lkQ3Ri2NQhV)]
|
||||||
|
- **<big>Random</big>** : get a random item of slice, return its index, when slice is empty, return -1.
|
||||||
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/en/api/packages/slice.md#Random)]
|
||||||
|
|
||||||
<h3 id="stream"> 19. Stream package implements a sequence of elements supporting sequential and operations. this package is an experiment to explore if stream in go can work as the way java does. its function is very limited. <a href="#index">index</a></h3>
|
<h3 id="stream"> 19. Stream package implements a sequence of elements supporting sequential and operations. this package is an experiment to explore if stream in go can work as the way java does. its function is very limited. <a href="#index">index</a></h3>
|
||||||
|
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
<br/>
|
<br/>
|
||||||
|
|
||||||

|

|
||||||
[](https://github.com/duke-git/lancet/releases)
|
[](https://github.com/duke-git/lancet/releases)
|
||||||
[](https://pkg.go.dev/github.com/duke-git/lancet/v2)
|
[](https://pkg.go.dev/github.com/duke-git/lancet/v2)
|
||||||
[](https://goreportcard.com/report/github.com/duke-git/lancet/v2)
|
[](https://goreportcard.com/report/github.com/duke-git/lancet/v2)
|
||||||
[](https://github.com/duke-git/lancet/actions/workflows/codecov.yml)
|
[](https://github.com/duke-git/lancet/actions/workflows/codecov.yml)
|
||||||
@@ -1098,6 +1098,14 @@ import "github.com/duke-git/lancet/v2/random"
|
|||||||
- **<big>RandUniqueIntSlice</big>** : 生成一个不重复的长度为 n 的随机 int 切片。
|
- **<big>RandUniqueIntSlice</big>** : 生成一个不重复的长度为 n 的随机 int 切片。
|
||||||
[[doc](https://github.com/duke-git/lancet/blob/main/docs/api/packages/random.md#RandUniqueIntSlice)]
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/api/packages/random.md#RandUniqueIntSlice)]
|
||||||
[[play](https://go.dev/play/p/uBkRSOz73Ec)]
|
[[play](https://go.dev/play/p/uBkRSOz73Ec)]
|
||||||
|
- **<big>RandSymbolChar</big>** : 生成给定长度的随机符号字符串。
|
||||||
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/api/packages/random.md#RandSymbolChar)]
|
||||||
|
[[play](https://go.dev/play/p/uBkRSOz73Ec)]
|
||||||
|
- **<big>RandFloat</big>** : 生成随机float64数字,可以指定范围和精度。
|
||||||
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/api/packages/random.md#RandFloat)]
|
||||||
|
[[play](https://go.dev/play/p/uBkRSOz73Ec)]
|
||||||
|
- **<big>RandFloats</big>** : 生成随机float64数字切片,可以指定长度,范围和精度.
|
||||||
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/api/packages/random.md#RandFloats)]
|
||||||
|
|
||||||
<h3 id="retry"> 17. retry 重试执行函数直到函数运行成功或被 context cancel。 <a href="#index">回到目录</a></h3>
|
<h3 id="retry"> 17. retry 重试执行函数直到函数运行成功或被 context cancel。 <a href="#index">回到目录</a></h3>
|
||||||
|
|
||||||
@@ -1341,6 +1349,9 @@ import "github.com/duke-git/lancet/v2/slice"
|
|||||||
- **<big>Partition</big>** : 根据给定的predicate判断函数分组切片元素。
|
- **<big>Partition</big>** : 根据给定的predicate判断函数分组切片元素。
|
||||||
[[doc](https://github.com/duke-git/lancet/blob/main/docs/api/packages/slice.md#Partition)]
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/api/packages/slice.md#Partition)]
|
||||||
[[play](https://go.dev/play/p/lkQ3Ri2NQhV)]
|
[[play](https://go.dev/play/p/lkQ3Ri2NQhV)]
|
||||||
|
- **<big>Random</big>** : 随机返回切片中元素以及下标, 当切片长度为0时返回下标-1。
|
||||||
|
[[doc](https://github.com/duke-git/lancet/blob/main/docs/api/packages/slice.md#Random)]
|
||||||
|
|
||||||
|
|
||||||
<h3 id="stream"> 19. stream 流,该包仅验证简单的 stream 实现,功能有限。 <a href="#index">回到目录</a></h3>
|
<h3 id="stream"> 19. stream 流,该包仅验证简单的 stream 实现,功能有限。 <a href="#index">回到目录</a></h3>
|
||||||
|
|
||||||
|
|||||||
@@ -29,8 +29,11 @@ import (
|
|||||||
- [RandLower](#RandLower)
|
- [RandLower](#RandLower)
|
||||||
- [RandNumeral](#RandNumeral)
|
- [RandNumeral](#RandNumeral)
|
||||||
- [RandNumeralOrLetter](#RandNumeralOrLetter)
|
- [RandNumeralOrLetter](#RandNumeralOrLetter)
|
||||||
|
- [RandSymbolChar](#RandSymbolChar)
|
||||||
- [UUIdV4](#UUIdV4)
|
- [UUIdV4](#UUIdV4)
|
||||||
- [RandUniqueIntSlice](#RandUniqueIntSlice)
|
- [RandUniqueIntSlice](#RandUniqueIntSlice)
|
||||||
|
- [RandFloat](#RandFloat)
|
||||||
|
- [RandFloats](#RandFloats)
|
||||||
|
|
||||||
<div STYLE="page-break-after: always;"></div>
|
<div STYLE="page-break-after: always;"></div>
|
||||||
|
|
||||||
@@ -298,3 +301,55 @@ func main() {
|
|||||||
fmt.Println(result) //[0 4 7 1 5] (random)
|
fmt.Println(result) //[0 4 7 1 5] (random)
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### <span id="RandFloat">RandFloat</span>
|
||||||
|
|
||||||
|
<p>生成随机float64数字,可以指定范围和精度。</p>
|
||||||
|
|
||||||
|
<b>函数签名:</b>
|
||||||
|
|
||||||
|
```go
|
||||||
|
func RandFloat(min, max float64, precision int) float64
|
||||||
|
```
|
||||||
|
|
||||||
|
<b>实例:</b>
|
||||||
|
|
||||||
|
```go
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"github.com/duke-git/lancet/v2/random"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
floatNumber := random.RandFloat(1.0, 5.0, 2)
|
||||||
|
fmt.Println(floatNumber) //2.14 (random number)
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### <span id="RandFloats">RandFloats</span>
|
||||||
|
|
||||||
|
<p>生成随机float64数字切片,指定长度,范围和精度.</p>
|
||||||
|
|
||||||
|
<b>函数签名:</b>
|
||||||
|
|
||||||
|
```go
|
||||||
|
func RandFloats(n int, min, max float64, precision int) []float64
|
||||||
|
```
|
||||||
|
|
||||||
|
<b>实例:</b>
|
||||||
|
|
||||||
|
```go
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"github.com/duke-git/lancet/v2/random"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
floatNumbers := random.RandFloats(5, 1.0, 5.0, 2)
|
||||||
|
fmt.Println(floatNumber) //[3.42 3.99 1.3 2.38 4.23] (random)
|
||||||
|
}
|
||||||
|
```
|
||||||
@@ -32,6 +32,8 @@ import (
|
|||||||
- [RandSymbolChar](#RandSymbolChar)
|
- [RandSymbolChar](#RandSymbolChar)
|
||||||
- [UUIdV4](#UUIdV4)
|
- [UUIdV4](#UUIdV4)
|
||||||
- [RandUniqueIntSlice](#RandUniqueIntSlice)
|
- [RandUniqueIntSlice](#RandUniqueIntSlice)
|
||||||
|
- [RandFloat](#RandFloat)
|
||||||
|
- [RandFloats](#RandFloats)
|
||||||
|
|
||||||
<div STYLE="page-break-after: always;"></div>
|
<div STYLE="page-break-after: always;"></div>
|
||||||
|
|
||||||
@@ -300,3 +302,55 @@ func main() {
|
|||||||
fmt.Println(result) //[0 4 7 1 5] (random)
|
fmt.Println(result) //[0 4 7 1 5] (random)
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### <span id="RandFloat">RandFloat</span>
|
||||||
|
|
||||||
|
<p>Generate a random float64 number between [min, max) with specific precision.</p>
|
||||||
|
|
||||||
|
<b>Signature:</b>
|
||||||
|
|
||||||
|
```go
|
||||||
|
func RandFloat(min, max float64, precision int) float64
|
||||||
|
```
|
||||||
|
|
||||||
|
<b>Example:</b>
|
||||||
|
|
||||||
|
```go
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"github.com/duke-git/lancet/v2/random"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
floatNumber := random.RandFloat(1.0, 5.0, 2)
|
||||||
|
fmt.Println(floatNumber) //2.14 (random number)
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### <span id="RandFloats">RandFloats</span>
|
||||||
|
|
||||||
|
<p>Generate a slice of random float64 numbers of length n that do not repeat.</p>
|
||||||
|
|
||||||
|
<b>Signature:</b>
|
||||||
|
|
||||||
|
```go
|
||||||
|
func RandFloats(n int, min, max float64, precision int) []float64
|
||||||
|
```
|
||||||
|
|
||||||
|
<b>Example:</b>
|
||||||
|
|
||||||
|
```go
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"github.com/duke-git/lancet/v2/random"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
floatNumbers := random.RandFloats(5, 1.0, 5.0, 2)
|
||||||
|
fmt.Println(floatNumber) //[3.42 3.99 1.3 2.38 4.23] (random)
|
||||||
|
}
|
||||||
|
```
|
||||||
@@ -163,8 +163,8 @@ func RandUniqueIntSlice(n, min, max int) []int {
|
|||||||
return nums
|
return nums
|
||||||
}
|
}
|
||||||
|
|
||||||
// RandFloats generate a slice of random float64 of length n that do not repeat.
|
// RandFloats generate a slice of random float64 numbers of length n that do not repeat.
|
||||||
// Play: https://go.dev/play/p/uBkRSOz73Ec
|
// Play: todo
|
||||||
func RandFloats(n int, min, max float64, precision int) []float64 {
|
func RandFloats(n int, min, max float64, precision int) []float64 {
|
||||||
nums := make([]float64, n)
|
nums := make([]float64, n)
|
||||||
used := make(map[float64]struct{}, n)
|
used := make(map[float64]struct{}, n)
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ package random
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"regexp"
|
"regexp"
|
||||||
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
func ExampleRandInt() {
|
func ExampleRandInt() {
|
||||||
@@ -151,3 +152,36 @@ func ExampleRandSymbolChar() {
|
|||||||
// true
|
// true
|
||||||
// 6
|
// 6
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func ExampleRandFloat() {
|
||||||
|
pattern := `^[\d{1}.\d{2}]+$`
|
||||||
|
reg := regexp.MustCompile(pattern)
|
||||||
|
|
||||||
|
num := RandFloat(1.0, 5.0, 2)
|
||||||
|
|
||||||
|
// check num is a random float in [1.0, 5.0)
|
||||||
|
result1 := num >= 1.0 && num < 5.0
|
||||||
|
result2 := reg.MatchString(strconv.FormatFloat(num, 'f', -1, 64))
|
||||||
|
|
||||||
|
fmt.Println(result1)
|
||||||
|
fmt.Println(result2)
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
|
// true
|
||||||
|
}
|
||||||
|
|
||||||
|
func ExampleRandFloats() {
|
||||||
|
isInRange := true
|
||||||
|
numbers := RandFloats(5, 1.0, 5.0, 2)
|
||||||
|
for _, n := range numbers {
|
||||||
|
isInRange = (n >= 1.0 && n < 5.0)
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println(isInRange)
|
||||||
|
fmt.Println(len(numbers))
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
|
// 5
|
||||||
|
}
|
||||||
|
|||||||
@@ -174,8 +174,7 @@ func TestRandFloat(t *testing.T) {
|
|||||||
assert := internal.NewAssert(t, "TestRandFloat")
|
assert := internal.NewAssert(t, "TestRandFloat")
|
||||||
|
|
||||||
r1 := RandFloat(1.1, 10.1, 2)
|
r1 := RandFloat(1.1, 10.1, 2)
|
||||||
t.Log(r1)
|
assert.GreaterOrEqual(r1, 1.1)
|
||||||
assert.GreaterOrEqual(r1, 5.0)
|
|
||||||
assert.Less(r1, 10.1)
|
assert.Less(r1, 10.1)
|
||||||
|
|
||||||
r2 := RandFloat(1.1, 1.1, 2)
|
r2 := RandFloat(1.1, 1.1, 2)
|
||||||
@@ -190,8 +189,10 @@ func TestRandFloats(t *testing.T) {
|
|||||||
t.Parallel()
|
t.Parallel()
|
||||||
assert := internal.NewAssert(t, "TestRandFloats")
|
assert := internal.NewAssert(t, "TestRandFloats")
|
||||||
|
|
||||||
result := RandFloats(5, 1.0, 5.0, 2)
|
numbers := RandFloats(5, 1.0, 5.0, 2)
|
||||||
t.Log("TestRandFloats result: ", result)
|
for _, n := range numbers {
|
||||||
|
assert.Equal(true, (n >= 1.0 && n < 5.0))
|
||||||
|
}
|
||||||
|
|
||||||
assert.Equal(len(result), 5)
|
assert.Equal(len(numbers), 5)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -200,7 +200,7 @@ func ExampleIsDns() {
|
|||||||
|
|
||||||
// Output:
|
// Output:
|
||||||
// true
|
// true
|
||||||
// false
|
// true
|
||||||
// false
|
// false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user