A set of a high performance string tools that helps to build strings from templates and process text faster than with fmt
!!!.
C#, Python programmers style
- {0}
, {name}
that faster then fmt
does:
text_utils.go
)This is a GO module for template text formatting in syntax like in C# or/and Python using:
{n}
, n here is a number to notes order of argument list to use i.e. {0}
, {1}
{name}
to notes arguments by name i.e. {name}
, {last_name}
, {address}
and so on …i.e. you have following template: "Hello {0}, we are greeting you here: {1}!"
if you call Format with args “manager” and “salesApp” :
formattedStr := stringFormatter.Format("Hello {0}, we are greeting you here: {1}!", "manager", "salesApp")
you get string "Hello manager, we are greeting you here: salesApp!"
i.e. you have following template: "Hello {user} what are you doing here {app} ?"
if you call FormatComplex
with args "vpupkin"
and "mn_console"
FormatComplex("Hello {user} what are you doing here {app} ?", map[string]any{"user":"vpupkin", "app":"mn_console"})
you get string "Hello vpupkin what are you doing here mn_console ?"
another example is:
strFormatResult = stringFormatter.FormatComplex(
"Current app settings are: ipAddr: {ipaddr}, port: {port}, use ssl: {ssl}.",
map[string]any{"ipaddr":"127.0.0.1", "port":5432, "ssl":false},
)
a result will be: "Current app settings are: ipAddr: 127.0.0.1, port: 5432, use ssl: false."
`
For more convenient lines formatting we should choose how arguments are representing in output text,
stringFormatter
supports following format options:
{0:B}, 15 outputs -> 1111
{0:B8}, 15 outputs -> 00001111
{0:X}, 250 outputs -> fa
{0:X4}, 250 outputs -> 00fa
{0:o}, 11 outputs -> 14
{0:E2}, 191.0478 outputs -> 1.91e+02
{0:F}, 10.4567890 outputs -> 10.456789
{0:F4}, 10.4567890 outputs -> 10.4568
{0:F8}, 10.4567890 outputs -> 10.45678900
{0:P100}, 12 outputs -> 12%
benchmark could be running using following commands from command line:
Format
result - go test -bench=Format -benchmem -cpu 1
fmt
result - go test -bench=Fmt -benchmem -cpu 1
MapToString
function allows to convert map with primitive key to string using format, including key and value, e.g.:
{key} => {value}
{key} : {value}
{value}
For example:
options := map[string]any{
"connectTimeout": 1000,
"useSsl": true,
"login": "sa",
"password": "sa",
}
str := stringFormatter.MapToString(&options, "{key} : {value}", ", ")
// NOTE: order of key-value pairs is not guranteed though
// str will be something like:
"connectTimeout : 1000, useSsl : true, login : sa, password : sa"
MapToStr
result - go test -bench=MapToStr -benchmem -cpu 1