我写了这段代码,它将一个小写的英语短语翻译成猪拉丁。
package main
import (
"fmt"
"strings"
"bufio"
"github.com/stretchr/stew/slice"
"regexp"
"os"
)
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(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, " "))
}
但是,它对短语中的最后一个单词没有任何作用。
如果我使用“快速的棕色狐狸跳过懒狗”这句话,我会得到“ ethay uickqayownbray oxfay umpedjay overay ethay
azylay狗”
这里的一切都正确,除了硬道理!为什么不起作用?如果我使用“ hello world”作为短语,也会发生同样的事情。
软件包bufio
func(* Reader)ReadString
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
问题内容: 运行以下代码时,出现此错误“主循环’builtin_function_or_method’对象不可迭代”: 我有搜索stackoverflow,但是找不到我的问题的答案… 我检查了错别字,但找不到任何错误。请帮我! 问题答案: 直接回答 在这里的代码中: 更改为。 如果您想进一步了解此错误,请阅读以下内容: 调试时,最好删除try … except块,尤其是“ expect Excep
问题内容: 我已经在堆栈溢出中给出的答案的帮助下更正了代码。我想循环通过逗号分隔的Id字符串,但无法这样做。下面给出的过程仅更新第一条记录,而不更新其他记录。需要进行哪些更正,才能循环通过逗号分隔的字符串。这是我的SP的代码 该代码如该帖子的答案中所提供。 我尝试使用find_in_set()函数,但仅当我从头开始传递id时才起作用,而如果我随机传递id则不起作用。这是我的表格脚本 int(11)
对于以下字符串,大小输出不正确。为什么会这样?我该如何解决? 我试着逐字符遍历str,这样我就可以把它读入向量
问题内容: 我想知道我什么时候做类似的事情 创建新字符串或返回视图/迭代器 问题答案: Python会进行逐个切片,这意味着每次切片时(非常琐碎的切片(例如)除外),它都会将所有数据复制到一个新的字符串对象中。 根据一位开发人员的说法,之所以做出此选择是因为 [按引用切片]方法更复杂,更难实现并且可能导致意外行为。 例如: 使用“按切片复制”设计,可以立即释放字符串。尽管您只对第一个字符感兴趣,但
问题内容: 我有一个字符串,例如: 其中(逗号)将始终是最后一个字符的第三个字符,也就是。 我正在考虑删除’,’的方法,但只能考虑将字符串转换为列表,将其删除,然后将其转换回字符串。但是,对于简单任务而言,这似乎有点过多。 如何以更简单的方式完成此任务? 问题答案: 通常,您只需执行以下操作: 该给你一个字符串,最多,但不包括你要删除的逗号()和给你另一个字符串开始一个字符超出了逗号()。 然后,
本节我们探索的主题是迭代与循环。循环通常在计算机编程用用于自动执行重复性任务。 在Python中最常用的迭代形式就是for循环了。for循环允许你迭代出列表中所有的项,迭代出来后你可以做任何你想做的事情。 比如,我们创建了一个列表,并打印出其中所有元素的平方。 >>> for value in [0, 1, 2, 3, 4, 5]: ... print(value * value) ... 0 1