1 回答

TA貢獻1796條經驗 獲得超4個贊
包緩沖區
func (*Reader) 讀取字符串
func?(b?*Reader)?ReadString(delim?byte)?(string,?error)ReadString 一直讀取到輸入中第一次出現 delim,返回一個包含數據的字符串,直到并包括分隔符。如果 ReadString 在找到分隔符之前遇到錯誤,它會返回錯誤之前讀取的數據和錯誤本身(通常是 io.EOF)。當且僅當返回的數據不以 delim 結尾時,ReadString 返回 err != nil。
返回包含數據的字符串,包括分隔符。
擺脫任何尾隨換行符:"\n"
或"\r\n"
。要快速修復,請寫:
sentence?:=?strings.Split(strings.TrimSpace(sentenceraw),?"?")
例如,
package main
import (
? ? "bufio"
? ? "fmt"
? ? "os"
? ? "regexp"
? ? "strings"
? ? "github.com/stretchr/stew/slice"
)
func main() {
? ? lst := []string{"sh", "gl", "ch", "ph", "tr", "br", "fr", "bl", "gr", "st", "sl", "cl", "pl", "fl", "th"}
? ? reader := bufio.NewReader(os.Stdin)
? ? fmt.Print("Type what you would like translated into pig-latin and press ENTER: ")
? ? sentenceraw, _ := reader.ReadString('\n')
? ? sentence := strings.Split(strings.TrimSpace(sentenceraw), " ")
? ? isAlpha := regexp.MustCompile(`^[A-Za-z]+$`).MatchString
? ? newsentence := make([]string, 0)
? ? for _, i := range sentence {
? ? ? ? if slice.Contains([]byte{'a', 'e', 'i', 'o', 'u'}, i[0]) {
? ? ? ? ? ? newsentence = append(newsentence, strings.Join([]string{string(i), "ay"}, ""))
? ? ? ? } else if slice.Contains(lst, string(i[0])+string(i[1])) {
? ? ? ? ? ? newsentence = append(newsentence, strings.Join([]string{string(i[2:]), string(i[:2]), "ay"}, ""))
? ? ? ? } else if !isAlpha(string(i)) {
? ? ? ? ? ? newsentence = append(newsentence, strings.Join([]string{string(i)}, ""))
? ? ? ? } else {
? ? ? ? ? ? newsentence = append(newsentence, strings.Join([]string{string(i[1:]), string(i[0]), "ay"}, ""))
? ? ? ? }
? ? }
? ? fmt.Println(strings.Join(newsentence, " "))
}
輸出:
Type what you would like translated into pig-latin and press ENTER: hello world
ellohay orldway
- 1 回答
- 0 關注
- 121 瀏覽
添加回答
舉報