在Go中使用正则表达式拆分字符串

时间:2010-12-16 22:41:31

标签: regex go string-split

我是Go的新手,到目前为止一直很享受。我正在尝试找到一种使用正则表达式而不是字符串来拆分字符串的好方法。感谢

http://nsf.github.com/go/strings.html?f:Split

6 个答案:

答案 0 :(得分:15)

我根据java,c#,php中正则表达式拆分函数的行为制作了一个正则表达式 - 拆分函数。它只返回一个字符串数组,没有索引信息。

func RegSplit(text string, delimeter string) []string {
    reg := regexp.MustCompile(delimeter)
    indexes := reg.FindAllStringIndex(text, -1)
    laststart := 0
    result := make([]string, len(indexes) + 1)
    for i, element := range indexes {
            result[i] = text[laststart:element[0]]
            laststart = element[1]
    }
    result[len(indexes)] = text[laststart:len(text)]
    return result
}

示例:

fmt.Println(RegSplit("a1b22c333d", "[0-9]+"))

结果:

[a b c d]

答案 1 :(得分:9)

如果您只想分割某些字符,可以使用strings.FieldsFunc,否则我会使用regexp.FindAllString

答案 2 :(得分:8)

regexp.Split()函数是执行此操作的最佳方式。

答案 3 :(得分:5)

使用regexp.Split将字符串分成以模式为定界符的字符串片段。

package main

import (
    "fmt"
    "regexp"
)

func main() {
    re := regexp.MustCompile("[0-9]+")
    txt := "Have9834a908123great10891819081day!"

    split := re.Split(txt, -1)
    set := []string{}

    for i := range split {
        set = append(set, split[i])
    }

    fmt.Println(set) // ["Have", "a", "great", "day!"]
}

答案 4 :(得分:2)

您应该能够创建自己的split函数,该函数循环遍历RegExp.FindAllString的结果,将插入的子字符串放入新数组中。

http://nsf.github.com/go/regexp.html?m:Regexp.FindAllString

答案 5 :(得分:0)

我在寻找答案的同时发现了这个旧帖子。我是Go的新手,但是对于当前版本的Go,这些答案似乎过于复杂。下面的简单函数返回与上面相同的结果。

package main

import (
    "fmt"
    "regexp"
)

func goReSplit(text string, pattern string) []string {
    regex := regexp.MustCompile(pattern)
    result := regex.Split(text, -1)
    return result
}

func main() {
    fmt.Printf("%#v\n", goReSplit("Have9834a908123great10891819081day!", "[0-9]+"))
}