Skip to content

Latest commit

 

History

History
326 lines (228 loc) · 9.17 KB

readme.md

File metadata and controls

326 lines (228 loc) · 9.17 KB

字符串转换工具, 类型转换工具, 模板渲染, 动态sql



转换函数

支持 string, []byte, bool, int, int8, int16, int32, int64, uint, uint8, uint16, uint32, uint64, float32, float64. 转换失败会返回该类型的零值.

zstr.GetString(1)       // 1
zstr.GetBool(1)         // true
zstr.GetInt(true)       // 1
zstr.GetFloat32("3.2")  // 3.2
zstr.Get...

转换失败时使用默认值

zstr.GetBool("xxx", true)         // true
zstr.GetInt("xxx", 1)       // 1
zstr.GetFloat32("xxx", float32(3.2))  // 3.2
zstr.Get...

Boolean转换说明

# 能转为true的数据
1, t, T, true, TRUE, True, y, Y, yes, YES, Yes, on, ON, On, ok, OK, Ok, enabled, ENABLED, Enabled
# 能转为false数据
nil, 0, f, F, false, FALSE, False, n, N, no, NO, No, off, OFF, Off, disable, DISABLE, Disable

扫描函数

支持 string, []byte, bool, int, int8, int16, int32, int64, uint, uint8, uint16, uint32, uint64, float32, float64.

将字符串扫描到指定变量

var a float64
var b uint32
var c bool
var d string
zstr.Scan("1", &a)  // 1
zstr.Scan("1", &b)  // 1
zstr.Scan("1", &c)  // true
zstr.Scan("1", &d)  // 1

将任何值扫描到指定变量

var a float64
var b uint32
var c bool
var d string
zstr.ScanAny(true, &a)     // 1
zstr.ScanAny(false, &b)    // 0
zstr.ScanAny("ok", &c)     // true
zstr.ScanAny(1.23, &d)     // 1.23

字符串工具

// 转为zstr.String类型
s := zstr.String("1")

转为指定类型

转换失败会返回该类型的零值. 支持 string, []byte, bool, int, int8, int16, int32, int64, uint, uint8, uint16, uint32, uint64, float32, float64

s.String()      // 获取string
s.GetBool()     // 获取bool
s.GetInt()      // 获取int
s.GetInt32()    // 获取int32
s.GetUint64()   // 获取uint64
s.GetFloat32()  // 获取float32
s.Get...

转换失败时使用默认值

s := zstr.String("xxx")
s.GetBool(true)     // true
s.GetInt(1)      // 1
s.GetInt32(2)    // 2
s.GetUint64(3)   // 3
s.GetFloat32(4)  // 4
s.Get...

扫描到变量

支持 string, []byte, bool, int, int8, int16, int32, int64, uint, uint8, uint16, uint32, uint64, float32, float64

var a float64
var b uint32
var c bool
var d string
_ = s.Scan(&a)
_ = s.Scan(&b)
_ = s.Scan(&c)
_ = s.Scan(&d)

模板渲染

将模板数据中的变量替换为指定数据

func Render(format string, values ...interface{}) string

format 表示模板数据. 示例: @a @b {@c} values 表示值. 参考值处理

示例

zstr.Render("{@a}e", "va") // 按顺序赋值
zstr.Render("@a @a e", "va0", "va1") // 按顺序赋值
zstr.Render("@a e", map[string]string{"a": "va"}) // 指定变量名赋值
zstr.Render("@a @b @c", zstr.KV{"a", "aValue"}, zstr.KV{"b", "bValue"}, zstr.KV{"c", "cValue"}) // 指定变量名赋值
zstr.Render("@a @b @c", zstr.KVs{{"a", "aValue"}, {"b", "bValue"}, {"c", "cValue"}}) // 指定变量名赋值
zstr.Render("@a @a @a", zstr.KV{"a[0]", "1"}, zstr.KV{"a", "2"}) // 指定变量名下标的优先级比指定变量名更高

变量名定义

模板变量用 @ 开头 模板变量推荐使用花括号{}包起来, 这样能精确的界定模板变量的开头和结尾. 注意花括号内可以有空格. 示例: @a, @a_b, @A.c, {@a....c}, {@9}, @0...A, { @a }, { @a}, {@a }, { @a }

变量细节参考 变量

渲染

模板渲染时遍历找出所有模板变量, 然后替换为匹配的变量值.

未对变量赋值时, 如果变量被花括号{}包裹, 那么会被替换为空字符串, 否则不会替换数据

比如 zstr.Render("@a {@b}", zstr.KV{"a", "aValue"}) 未对变量 b 进行赋值, 其输出结果为 aValue . 但是 zstr.Render("@a @b", zstr.KV{"a", "aValue"}) 输出结果为 aValue @b, 因为变量 b 没有被花括号{}包裹


值处理

参考源码 MakeMapOfValues

支持任何类型的map, 如 map[string]interface{}; map[int]int; map[int]string; map[string]int 等.

可以通过 zstr.KV 方式传入. 示例: zstr.MakeMapOfValues(zstr.KV{"k1", "v1"}, &zstr.KV{"k2", "v2"}).

可以通过 zstr.KVs 方式传入. 示例: zstr.MakeMapOfValues(zstr.KVs{{"k1", "v1"}, {"k2", "v2"}}).

也可以 zstr.KVzstr.KVs 混合传入. 示例 zstr.MakeMapOfValues(zstr.KVs{{"k1", "v1"}}, zstr.KV{"k2", "v2"}).

传参时支持顺序传值, 示例 zstr.MakeMapOfValues("v1", "v2"), 结果为 map[string]interface{}{"*[0]": "v1", "*[1]": "v2"}


变量

变量名支持 大小写字母; 数字; 下划线; 小数点; 变量名区分大小写; 变量开头和结尾不能是小数点, 但是变量中间可以有任意数量的小数点;

示例: @a, @a_b, @A.c, {@a....c}, {@9}, @0...A

模板匹配变量名方式

key 可以带下标, 下标从 0 开始, 如: a[0] 表示第一次出现的 a, a[5]表示第 6 次出现的 a. 星号 * 可以匹配任何变量名, 但是必须和下标一起使用, 下标从 0 开始, 如: *[0] 表示第 1 个变量, *[5] 表示第 6 个变量.

变量名匹配优先级

  1. 完全匹配变量名+下标
  2. 完全匹配变量名
  3. 星号+下标

如: a[0] > a > *[0]


动态sql

你是否会有根据不同的条件拼接不同的sql语句的痛苦, 使用 zstr动态sql 一次根治

func SqlRender(sqlTemplate string, values ...interface{}) string

sqlTemplate 表示要进行渲染的sql模板数据. 示例: select * from table where &a (&b |c) {&d like_start} values 表示值. 参考值处理

示例

zstr.SqlRender("select * from table where &a (&b |c)", map[string]interface{}{
    "a": 1,
    "b": 2,
    "c": 3,
})

模板语法说明

语法格式

(操作符)(变量名) {(操作符)(变量名)} {(操作符)(变量名) (标记)} {(操作符)(变量名) (标记) (选项)} {(操作符)(变量名) (选项)}

示例

&a {&a} {&a like} {&a like d} {&a d}

操作符

& 转为 and 变量名 标记 值, 一般用于表示一个条件.

| 转为 or 变量名 标记 值, 一般用于表示一个条件.

# 转为 . 自带 attention 选项.

@ 转为 , 一般用于表示一条语句. 自带 direct 选项, 且不会为字符串加上引号. attention 选项无效

变量名

模板变量用一个 操作符 开头. 模板变量推荐使用花括号{}包起来, 这样能精确的界定模板变量的开头和结尾, 还可以使用 标记选项 来改变行为. 花括号内允许有空格. 示例: &a, |a_b, #A.c, {&a....c}, {@9}, @0...A

变量细节参考 变量

标记

用于改变操作符 &| 的行为, 默认标记为 =

> >= < <= !=<> = in not_innotin like like_startlikestart like_endlikeend

选项

  • attention, 语法 a, 不会忽略参数值为该类型的零值. 表示该条件必须存在
  • direct, 语法 d, 直接将值写入sql语句中. 一般用于表示一段语句, 建议别用于表示一个值, 否则可能导致sql注入危险.
  • must, 语法 m, 必须传值, 否则会panic

渲染

渲染文本之前会缩进文本所有的空格, 所以要渲染的文本一般为单纯的sql语句, 不要将值写在文本中, 而是使用传参的方式, 这是使用sql的标准姿势

模板渲染时遍历找出所有模板语法, 然后按语法替换为不同的值. 一般情况下如果变量没有传参或为该类型的零值, 则替换为空字符串. 如果变量的值为nil, 不同的标志会转为不同的语句.


模板渲染和动态sql性能说明

我们写了一个专用函数用于替换正则查找规则, 经过 Benchmark 测试, 速度为正则查找变量方式的 230%. 具体的性能可以将代码clone后执行命令 go test -v -bench .