[英]Find index of Nth instance of substring in string in Swift
我的 Swift 应用程序涉及在 UITextView 中搜索文本。 用户可以在该文本视图中搜索某个子字符串,然后跳转到该文本视图中该字符串的任何实例(例如,第三个实例)。 我需要找出它们所在字符的整数值。
例如:
示例1:用户搜索“hello”,文本视图显示“hey hi hello, hey hi hello”,然后用户按向下箭头查看第二个实例。 我需要知道第二个 hello 中第一个h
的整数值(即 hello 中的 h 在文本视图中的 # 字符)。 整数值应为22
。
实施例2:用于“ABC”,而文本视图读取“ABCD”和他们正在寻找的第一个实例的用户搜索abc
,所以整数值应为1
(这是的整数值a
,因为它的第一个字符他们正在搜索的实例)。
如何获取用户正在搜索的字符的索引?
Xcode 11 • Swift 5 或更高版本
let sentence = "hey hi hello, hey hi hello"
let query = "hello"
var searchRange = sentence.startIndex..<sentence.endIndex
var indices: [String.Index] = []
while let range = sentence.range(of: query, options: .caseInsensitive, range: searchRange) {
searchRange = range.upperBound..<searchRange.upperBound
indices.append(range.lowerBound)
}
print(indices) // "[7, 21]\n"
另一种方法是NSRegularExpression
,它旨在轻松遍历字符串中的匹配项。 如果您使用.ignoreMetacharacters
选项,它不会应用任何复杂的通配符/正则表达式逻辑,而只会查找有问题的字符串。 所以考虑:
let string = "hey hi hello, hey hi hello" // string to search within
let searchString = "hello" // string to search for
let matchToFind = 2 // grab the second occurrence
let regex = try! NSRegularExpression(pattern: searchString, options: [.caseInsensitive, .ignoreMetacharacters])
您可以使用enumerateMatches
:
var count = 0
let range = NSRange(string.startIndex ..< string.endIndex, in: string)
regex.enumerateMatches(in: string, range: range) { result, _, stop in
count += 1
if count == matchToFind {
print(result!.range.location)
stop.pointee = true
}
}
或者你可以用matches(in:range:)
找到所有这些,然后抓住第n个:
let matches = regex.matches(in: string, range: range)
if matches.count >= matchToFind {
print(matches[matchToFind - 1].range.location)
}
显然,如果您愿意,您可以省略.ignoreMetacharacters
选项并允许用户执行正则表达式搜索(例如通配符、全词搜索、词首等)。
对于 Swift 2,请参阅此答案的先前修订版。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.