字符串索引
每一個(gè) String 值都有一個(gè)關(guān)聯(lián)的索引(index)類型,String.Index琉用,它對(duì)應(yīng)著字符串中的每一個(gè) Character 的位置峭范。
使用 startIndex 屬性可以獲取一個(gè) String 的第一個(gè) Character 的索引墓造。使用 endIndex 屬性可以獲取最后一個(gè) Character 的后一個(gè)位置的索引杏愤。因此,endIndex 屬性不能作為一個(gè)字符串的有效下標(biāo)驼仪。如果 String 是空串掸犬,startIndex 和 endIndex 是相等的。
通過(guò)調(diào)用 String 的 index(before:) 或 index(after:) 方法绪爸,可以立即得到前面或后面的一個(gè)索引湾碎。你還可以通過(guò)調(diào)用 index(_:offsetBy:) 方法來(lái)獲取對(duì)應(yīng)偏移量的索引
let welcome = "hello world"
print(welcome[welcome.startIndex])
// h
print(welcome[welcome.index(after: welcome.startIndex)])
// e
print(welcome[welcome.index(before: welcome.endIndex)])
// d
let someIndex = welcome.index(welcome.startIndex, offsetBy: 3)
print(welcome[someIndex])
// l
let anotherIndex = welcome.index(welcome.endIndex, offsetBy: -3)
print(welcome[anotherIndex])
// r
字符串的截取
Rang
A half-open interval from a lower bound up to, but not including, an upper bound.
從下界到上界的半開區(qū)間,但不包括上界(來(lái)自有道翻譯)奠货。
使用range(of: ) 可以根據(jù)給定的選項(xiàng)(條件)在給定的字符串范圍內(nèi)查找并返回給定選項(xiàng)(條件)第一次出現(xiàn)的范圍介褥。Range中包含兩個(gè)屬性lowerBound(下界)upperBound (上界)
示例
let someString = "今天你恰飯了嗎"
// someRang的類型是 Range<String.Index>?
if let someRange = someString.range(of: "恰飯") {
print(someString[someRange])
// 恰飯
print(someString[someRange.lowerBound])
// 恰
print(someString[someRange.upperBound])
// 了
}
從上面的示例中我們可以得出 lowerBound 類似我們給定條件的startIndex也就是“恰飯”的第一個(gè)索引,而upperBound類似我們給定條件的endIndex也就是“恰飯”最后一個(gè) Character 的后一個(gè)位置的索引递惋。
在空范圍內(nèi)柔滔,“下界”等于“上界”
下面是對(duì)微博來(lái)源字符串截取的一個(gè)示例:
let source = "<a href=\"http://weibo.com/\" rel=\"nofollow\">榜姐的iPhone客戶端</a>"
let startRang = source.range(of: ">")!
let endRang = source.range(of: "</")!
print(source[...startRang.lowerBound])
// <a rel="nofollow">
print(source[startRang.upperBound...])
// 榜姐的iPhone客戶端</a>
print(source[startRang.upperBound..<endRang.lowerBound])
// 榜姐的iPhone客戶端