[英]Iterate through alphabet in Swift
在 Obj-C 中,可以使用以下命令遍历字母表:
for (char x='A'; x<='Z'; x++) {
在 Swift 中这是不可能的。 知道我怎么能做到这一点吗?
在 Swift 中,您可以像这样在字符串上迭代字符:
斯威夫特 2
for char in "abcdefghijklmnopqrstuvwxyz".characters {
println(char)
}
斯威夫特 1.2
for char in "abcdefghijklmnopqrstuvwxyz" {
println(char)
}
不过可能有更好的方法。
这有点麻烦,但以下有效(Swift 3/4):
for value in UnicodeScalar("a").value...UnicodeScalar("z").value { print(UnicodeScalar(value)!) }
我怀疑这里的问题是“a”...“z”的含义对于不同的字符串编码可能会有所不同。
(旧东西)
也很麻烦,但没有额外的中间变量:
for letter in map(UnicodeScalar("a").value...UnicodeScalar("z").value, {(val: UInt32) -> UnicodeScalar in return UnicodeScalar(val); })
{
println(letter)
}
for i in 97...122{println(UnicodeScalar(i))}
为 Swift 3.0 及更高版本更新
let startChar = Unicode.Scalar("A").value
let endChar = Unicode.Scalar("Z").value
for alphabet in startChar...endChar {
if let char = Unicode.Scalar(alphabet) {
print(char)
}
}
Swift 4.2版本更容易
for char in "abcdefghijklmnopqrstuvwxyz" {
print(char)
}
此解决方案适用于 Swift 3.0,并且将打印出每个 OP 请求的值:
"ABCDEFGHIJKLMNOPQRSTUVWXYZ".characters.flatMap { print($0) }
或者为您提供一组字母:
let alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ".characters.flatMap { $0.description }
extension ClosedRange where Bound == UnicodeScalar {
func toArray() -> [UnicodeScalar] {
(lowerBound.value...upperBound.value).compactMap { UnicodeScalar($0) }
}
}
extension ClosedRange where Bound == String {
func toArray() -> [UnicodeScalar]? {
guard let lower = lowerBound.first?.unicodeScalars.first,
let upper = upperBound.first?.unicodeScalars.first else { return nil }
return (lower...upper).toArray()
}
}
("a"..."z").toArray() // option 1
(UnicodeScalar("a")...UnicodeScalar("z")).toArray() // option 2
“纯函数式” Swift 5方式:
(Unicode.Scalar("A").value...Unicode.Scalar("Z").value).forEach({
let letter = Unicode.Scalar($0)!
print(letter)
/* do other stuff with letter here */
})
你试过这个吗?
for var myChar:CChar = 65 ; myChar <= 90 ; ++myChar {
let x:String = String(format: "%c", myChar)
println(x)
}
如果您已经知道字符代码
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.