Go는 정규표현식(regular expressions)를 위한 내장 기능을 지원합니다. 여기에 Go에서의 일반적인 정규식 관련 작업의 몇 가지 예시가 있습니다. |
|
package main
|
|
import "bytes"
import "fmt"
import "regexp"
|
|
func main() {
|
|
다음은 패턴이 문자열과 일치하는지를 검사합니다. |
match, _ := regexp.MatchString("p([a-z]+)ch", "peach")
fmt.Println(match)
|
위에서는 문자열 패턴을 바로 사용했지만, 다른 정규식 작업을 위해선 최적화된 |
r, _ := regexp.Compile("p([a-z]+)ch")
|
이 구조체에선 많은 메서드를 사용할 수 있습니다. 다음은 이전에 봤던것과 같은 일치 검사입니다. |
fmt.Println(r.MatchString("peach"))
|
다음은 정규식과 일치하는 문자열을 찾습니다. |
fmt.Println(r.FindString("peach punch"))
|
다음 메서드 또한 첫번째로 매칭되는 문자열을 찾지만 일치하는 텍스트 대신 일치하는 텍스트의 첫 인덱스와 마지막 인덱스를 반환합니다. |
fmt.Println(r.FindStringIndex("peach punch"))
|
|
fmt.Println(r.FindStringSubmatch("peach punch"))
|
유사하게 다음은 전체 일치와 부분 일치의 인덱스에 대한 정보를 반환합니다. |
fmt.Println(r.FindStringSubmatchIndex("peach punch"))
|
|
fmt.Println(r.FindAllString("peach punch pinch", -1))
|
다음의 |
fmt.Println(r.FindAllStringSubmatchIndex(
"peach punch pinch", -1))
|
다음 함수의 두번째 인자에 음이 아닌 정수를 전달하면 일치 항목의 갯수를 제한합니다. |
fmt.Println(r.FindAllString("peach punch pinch", 2))
|
위의 예시들은 문자열 인자를 사용하며 |
fmt.Println(r.Match([]byte("peach")))
|
정규표현식으로 상수를 만들때 |
r = regexp.MustCompile("p([a-z]+)ch")
fmt.Println(r)
|
|
fmt.Println(r.ReplaceAllString("a peach", "<fruit>"))
|
|
in := []byte("a peach")
out := r.ReplaceAllFunc(in, bytes.ToUpper)
fmt.Println(string(out))
}
|
$ go run regular-expressions.go
true
true
peach
[0 5]
[peach ea]
[0 5 1 3]
[peach punch pinch]
[[0 5 1 3] [6 11 7 9] [12 17 13 15]]
[peach punch]
true
p([a-z]+)ch
a <fruit>
a PEACH
|
|
For a complete reference on Go regular expressions checkthe |
다음 예제: JSON.