Golang 递增字符串中的数字(使用符文)
Golang Increcementing numbers in strings (using runes)
我有一个混合了字符和数字的字符串,但我想递增最后一个恰好是数字的字符,这就是我所拥有的,它可以工作,但是一旦我达到 10,符文就会变黑,因为 10十进制为零,有更好的方法吗?
package main
import (
"fmt"
)
func main() {
str := "version-1.1.0-8"
rStr := []rune(str)
last := rStr[len(rStr)-1]
rStr[len(rStr)-1] = last + 1
}
所以这适用于 str := "version-1.1.0-8" = version-1.1.0-9
str := version-1.1.0-9 = version-1.1.0-
我明白为什么会这样,但我不知道如何解决
您的目的是增加最后一个符文所代表的数字,因此您应该这样做:解析该数字,将其作为数字增加,然后 "re-encode" 将其转换为字符串。
不能对单个符文进行操作,一旦达到10
,就只能用2个符文表示。另一个问题是如果最后一个数字是 19
,增加它需要改变以前的符文(而不是添加新的符文)。
虽然解析数字并重新编码比人们想象的要容易得多。
您可以利用 fmt
package's fmt.Sscanf()
and fmt.Sprintf()
功能。解析和重新编码只是一个函数调用。
让我们将此功能包装到一个函数中:
const format = "version-%d.%d.%d-%d"
func incLast(s string) (string, error) {
var a, b, c, d int
if _, err := fmt.Sscanf(s, format, &a, &b, &c, &d); err != nil {
return "", err
}
d++
return fmt.Sprintf(format, a, b, c, d), nil
}
正在测试:
s := "version-1.1.0-8"
for i := 0; i < 13; i++ {
var err error
if s, err = incLast(s); err != nil {
panic(err)
}
fmt.Println(s)
}
输出(在 Go Playground 上尝试):
version-1.1.0-9
version-1.1.0-10
version-1.1.0-11
version-1.1.0-12
version-1.1.0-13
version-1.1.0-14
version-1.1.0-15
version-1.1.0-16
version-1.1.0-17
version-1.1.0-18
version-1.1.0-19
version-1.1.0-20
version-1.1.0-21
另一种选择是只解析和重新编码最后一部分,而不是完整的版本文本。这是它的样子:
func incLast2(s string) (string, error) {
i := strings.LastIndexByte(s, '-')
if i < 0 {
return "", fmt.Errorf("invalid input")
}
d, err := strconv.Atoi(s[i+1:])
if err != nil {
return "", err
}
d++
return s[:i+1] + strconv.Itoa(d), nil
}
测试和输出是一样的。在 Go Playground.
上试试这个
我有一个混合了字符和数字的字符串,但我想递增最后一个恰好是数字的字符,这就是我所拥有的,它可以工作,但是一旦我达到 10,符文就会变黑,因为 10十进制为零,有更好的方法吗?
package main
import (
"fmt"
)
func main() {
str := "version-1.1.0-8"
rStr := []rune(str)
last := rStr[len(rStr)-1]
rStr[len(rStr)-1] = last + 1
}
所以这适用于 str := "version-1.1.0-8" = version-1.1.0-9 str := version-1.1.0-9 = version-1.1.0-
我明白为什么会这样,但我不知道如何解决
您的目的是增加最后一个符文所代表的数字,因此您应该这样做:解析该数字,将其作为数字增加,然后 "re-encode" 将其转换为字符串。
不能对单个符文进行操作,一旦达到10
,就只能用2个符文表示。另一个问题是如果最后一个数字是 19
,增加它需要改变以前的符文(而不是添加新的符文)。
虽然解析数字并重新编码比人们想象的要容易得多。
您可以利用 fmt
package's fmt.Sscanf()
and fmt.Sprintf()
功能。解析和重新编码只是一个函数调用。
让我们将此功能包装到一个函数中:
const format = "version-%d.%d.%d-%d"
func incLast(s string) (string, error) {
var a, b, c, d int
if _, err := fmt.Sscanf(s, format, &a, &b, &c, &d); err != nil {
return "", err
}
d++
return fmt.Sprintf(format, a, b, c, d), nil
}
正在测试:
s := "version-1.1.0-8"
for i := 0; i < 13; i++ {
var err error
if s, err = incLast(s); err != nil {
panic(err)
}
fmt.Println(s)
}
输出(在 Go Playground 上尝试):
version-1.1.0-9
version-1.1.0-10
version-1.1.0-11
version-1.1.0-12
version-1.1.0-13
version-1.1.0-14
version-1.1.0-15
version-1.1.0-16
version-1.1.0-17
version-1.1.0-18
version-1.1.0-19
version-1.1.0-20
version-1.1.0-21
另一种选择是只解析和重新编码最后一部分,而不是完整的版本文本。这是它的样子:
func incLast2(s string) (string, error) {
i := strings.LastIndexByte(s, '-')
if i < 0 {
return "", fmt.Errorf("invalid input")
}
d, err := strconv.Atoi(s[i+1:])
if err != nil {
return "", err
}
d++
return s[:i+1] + strconv.Itoa(d), nil
}
测试和输出是一样的。在 Go Playground.
上试试这个