String Functions->문자열 함수
#
// 표준 라이브러리의 `strings` 패키지는 많은 유용한 문자열 관련 함수들을 제공합니다.
// 이 패키지에 대한 감을 얻을 수 있는 몇 가지 예시가 있습니다.
package main
import s "strings"
import "fmt"
// `fmt.Println`를 짧은 이름으로 aliasing 합니다. 이는 아래에서 많이 사용합니다.
var p = fmt.Println
func main() {
// `strings`에서 사용할 수 있는 몇 가지 함수의 예시입니다.
// 이들은 문자열 객체 자체의 메서드가 아니라 패키지의 함수이기 때문에 문자열을 함수의 첫번째 인자에 전달해줘야 합니다.
// [`strings`](http://golang.org/pkg/strings/) 패키지 문서에서 더 많은 함수들을 찾아볼 수 있습니다.
p("Contains: ", s.Contains("test", "es"))
p("Count: ", s.Count("test", "t"))
p("HasPrefix: ", s.HasPrefix("test", "te"))
p("HasSuffix: ", s.HasSuffix("test", "st"))
p("Index: ", s.Index("test", "e"))
p("Join: ", s.Join([]string{"a", "b"}, "-"))
p("Repeat: ", s.Repeat("a", 5))
p("Replace: ", s.Replace("foo", "o", "0", -1))
p("Replace: ", s.Replace("foo", "o", "0", 1))
p("Split: ", s.Split("a-b-c-d-e", "-"))
p("ToLower: ", s.ToLower("TEST"))
p("ToUpper: ", s.ToUpper("test"))
p()
// `strings`의 일부는 아니지만 언급할만한게 있는데, 바이트에서의 문자열 길이와 인덱스를 통한 바이트를 구하는 메커니즘입니다.
p("Len: ", len("hello"))
p("Char:", "hello"[1])
}
// 참고로 위의 `len`과 인덱싱은 바이트 수준에서 동작합니다.
// Go는 UTF-8로 인코딩된 문자열을 사용하므로 종종 유용합니다.
// 잠재적으로 다중 바이트 바이트 문자로 작업하는 경우 인코딩 인식 작업을 하고자 할겁니다.
// 좀 더 자세한 내용은 [strings, bytes, runes and characters in Go](https://blog.golang.org/strings)를 보십시오.
$ go run string-functions.go
Contains: true
Count: 2
HasPrefix: true
HasSuffix: true
Index: 1
Join: a-b
Repeat: aaaaa
Replace: f00
Replace: f0o
Split: [a b c d e]
ToLower: test
ToUpper: TEST
Len: 5
Char: 101