-1

我有一个混合了字符和数字的字符串,但是我想增加最后一个恰好是数字的字符,这就是我所拥有的,它可以工作,但是一旦我达到 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-

我明白它为什么会发生,但我不知道如何解决它

4

1 回答 1

1

您的意图是增加最后一个符文表示的数字,因此您应该这样做:解析该数字,将其作为数字增加,然后将其“重新编码”为字符串。

您不能对单个符文进行操作,因为一旦数量达到10,则只能使用 2 个符文来表示。另一个问题是,如果最后一个数字是19,增加它需要改变以前的符文(而不是添加新的符文)。

解析数字和重新编码比人们想象的要容易得多。

您可以利用fmt包的fmt.Sscanf()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上试试这个。

于 2018-11-27T19:17:12.917 回答