- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
0 -6ren">
如何使用 go 在 []rune 中找到一个字符串的偏移索引?
我可以用字符串类型完成这项工作。
if i := strings.Index(input[offset:], "}}"); i > 0 {打印(i);}
但我需要 rune 。
我有一个 rune ,想要获取偏移索引。
如何使用 go 中的 rune 类型来完成这项工作?
更多理解需求的例子:
int offset=0//mean start from 0 (this is important for me)
string text="123456783}}56"
if i := strings.Index(text[offset:], "}}"); i > 0 {print(i);}
这个例子的输出是:9
但我想用[] rune 类型(文本变量)来做这件事
可以吗?
查看我当前的代码:https://play.golang.org/p/seImKzVpdh
加油。
最佳答案
编辑#2:您再次指出了问题的新类型“含义”:您想在 string
中搜索 []rune
。
回答:标准库不直接支持这个。但是用 2 个 for
循环很容易实现它:
func search(text []rune, what string) int {
whatRunes := []rune(what)
for i := range text {
found := true
for j := range whatRunes {
if text[i+j] != whatRunes[j] {
found = false
break
}
}
if found {
return i
}
}
return -1
}
测试它:
value := []rune("123}456}}789")
result := search(value, "}}")
fmt.Println(result)
输出(在 Go Playground 上尝试):
7
编辑:您更新了问题,表明您想要在 rune
中搜索 string
。
您可以使用简单的类型转换轻松地将 []rune
转换为 string
:
toSearchRunes := []rune{'}', '}'}
toSearch := string(toSearchRunes)
然后,您可以像在示例中那样使用 strings.Index()
:
if i := strings.Index(text[offset:], toSearch); i > 0 {
print(i)
}
在 Go Playground 上试试。
原回答如下:
Go 中的 string
值存储为 UTF-8 编码字节。如果找到给定的子字符串, strings.Index()
会返回字节位置。
所以基本上您想要的是将此字节位置转换为 rune 位置。 unicode/utf8
包包含用于告知 string
的 rune 计数或 rune 长度的实用函数: utf8.RuneCountInString()
。
所以基本上你只需要将子字符串传递给这个函数:
offset := 0
text := "123456789}}56"
if i := strings.Index(text[offset:], "}}"); i > 0 {
fmt.Println("byte-pos:", i, "rune-pos:", utf8.RuneCountInString(text[offset:i]))
}
text = "世界}}世界"
if i := strings.Index(text[offset:], "}}"); i > 0 {
fmt.Println("byte-pos:", i, "rune-pos:", utf8.RuneCountInString(text[offset:i]))
}
输出(在 Go Playground 上尝试):
byte-pos: 9 rune-pos: 9
byte-pos: 6 rune-pos: 2
注意:offset
也必须是一个字节位置,因为当像 string
那样 slice text[offset:]
时,索引被解释为字节索引。
如果要获取 rune
的索引,请使用 strings.IndexRune()
而不是 strings.Index()
。
关于string - 如何使用 go 在 rune 中找到偏移索引字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41956391/
package main var lettersLower = []rune("abcdefghijklmnopqrstuvwxyz") var lettersUpper = []rune("ABCD
我正在维护一些 Java 代码,我目前正在将它们转换为 C#。 Java 代码是这样做的: sendString(somedata + '\000'); 在 C# 中,我正在尝试做同样的事情: sen
我正在尝试使用 utf8 十六进制代码生成连续字符。例如第一部分,我称之为“基本”代码:259第二部分,我称之为“结束”代码:1(或,2,或 A,或 F,等等) 这些以字符串的形式出现。一旦我附加了结
我有一个字符串 MyString我想在这个数据中附加如下内容: MYString ("1", "a"), ("1", "b") //END result 我的代码是这样的: query :=
这是我的代码段: var converter = map[rune]rune {//some data} sample := "⌘こんにちは" var tmp string for _, runeVa
根据https://blog.golang.org/strings在我的测试中,看起来当我们 range 一个字符串时,我们得到的字符是 rune 类型,但是如果我们通过 str[index] 获取它
我有一个非常非常大的文本文件(比内存大得多)。我想做的是使用类似于: for record in myFile: process_record(); 添加的技巧是我的记录由空行分隔(中间有各种东西)
我想连接一个字符串文字和一个字 rune 字。由于语法不正确,"abc"'d' "efg" 会导致编译器错误: x.c:4:24: error: expected ',' or ';' before
我想连接一个字符串文字和一个字 rune 字。由于语法不正确,"abc"'d' "efg" 会导致编译器错误: x.c:4:24: error: expected ',' or ';' before
我在网上看到一个使用 golang 中的 rune() 函数的函数,但我很难找到它是什么。我正在阅读教程并且对文档没有经验,所以很难找到我要找的东西。 具体来说,我想看看为什么会失败...... fm
我正在查看 string.Map 函数,它必须采用返回 rune 的映射函数。我想通过调用来消除解析为 false 的 rune :unicode.IsPrint() func Map(映射 func
我在按字符排序字符串时遇到问题(要检查两个字符串是否是字谜,我想对它们都进行排序,并检查是否相等)。 我可以像这样得到字符串 s 的 []rune 表示: runes := make([]rune,
什么是rune在围棋? 我一直在谷歌搜索,但 Golang 只说一行: rune是 int32 的别名. 但是整数怎么会像交换案例一样到处使用呢? 下面是一个函数swapcase。什么是<=和 - ?
我正在使用具有此约束规则的泛型: type LineParser[T []rune | string] struct { } 我有那个结构的通用方法: func (it *LineParser[T])
我有一个包含波兰语字符的 csv,但是当我在 SAS 中导入时,某些波兰语字符被替换为“?”或任何其他随机变量,我该如何处理。我有一个所有可能的波兰语字符的列表,我不介意它被它的英语对应字符取代 最佳
我正在创建一个时尚的文本应用程序,但在某些地方出现错误(“字 rune 字中的字符太多”)。我只写了一个字母,但是当我粘贴它时,它会转换成许多这样的字母:“\uD83C\uDD89”,原始字母是“🆉
有点像 const X: char = '0x10FFFC'; 最佳答案 是的,使用\u{..}: const X: char = '\u{10FFFC}'; Playground 这种情况下的一个技
我有一个名为“ roケールストリングのキャッシュ最适化-v3-20160202_1047.pdf”的pdf文件。 使用Google标记管理器从下载URL获取文件名时,我得到的值为“%E4%BE%9B
程序目的: rune 密码 最终编辑: 我现在(感谢 非常有用的 由 Extremely 提供的答案 了不起的人 )完成了我一直在从事的项目;并且 - 对于 future 的读者,我还提供了完整的代码
如何在Scala中为垂直制表符('\v',ASCII 11)编写字 rune 字? '\v'不起作用。 (无效的转义字符)'\11'应该是,但是... scala> '\11'.toInt res13
我是一名优秀的程序员,十分优秀!