String+Extenstion.swift 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. //
  2. // String+Extenstion.swift
  3. // o2app
  4. //
  5. // Created by 刘振兴 on 2017/8/18.
  6. // Copyright © 2017年 zone. All rights reserved.
  7. //
  8. import Foundation
  9. import UIKit
  10. extension String {
  11. /// EZSE: Checks if string is empty or consists only of whitespace and newline characters
  12. public var isBlank: Bool {
  13. let trimmed = trimmingCharacters(in: .whitespacesAndNewlines)
  14. return trimmed.isEmpty
  15. }
  16. /// EZSE: split string using a spearator string, returns an array of string
  17. public func split(_ separator: String) -> [String] {
  18. return self.components(separatedBy: separator).filter {
  19. !$0.trim().isEmpty
  20. }
  21. }
  22. /// EZSE: split string with delimiters, returns an array of string
  23. public func split(_ characters: CharacterSet) -> [String] {
  24. return self.components(separatedBy: characters).filter {
  25. !$0.trim().isEmpty
  26. }
  27. }
  28. /// 字符串时间转 Date
  29. ///
  30. /// - Parameter formatter: 字符串时间的格式 yyyy-MM-dd/YYYY-MM-dd/HH:mm:ss/yyyy-MM-dd HH:mm:ss
  31. /// - Returns: Date
  32. func toDate(formatter: String) -> Date {
  33. let dateFormatter = DateFormatter()
  34. dateFormatter.locale = Locale.current
  35. dateFormatter.dateFormat = formatter
  36. let date = dateFormatter.date(from: self)
  37. return date!
  38. }
  39. func subString(from: Int, to: Int? = nil) -> String {
  40. if from >= self.length {
  41. return self
  42. }
  43. let startIndex = self.index(self.startIndex, offsetBy: from)
  44. if to == nil {
  45. return String(self[startIndex..<self.endIndex])
  46. }else {
  47. if from >= to! {
  48. return String(self[startIndex..<self.endIndex])
  49. }else {
  50. let endIndex = index(self.startIndex, offsetBy: to!)
  51. return String(self[startIndex..<endIndex])
  52. }
  53. }
  54. }
  55. /// 计算文本的高度
  56. func textHeight(fontSize: CGFloat, width: CGFloat) -> CGFloat {
  57. return self.boundingRect(with: CGSize(width: width, height: CGFloat(MAXFLOAT)), options: .usesLineFragmentOrigin, attributes: [.font: UIFont.systemFont(ofSize: fontSize)], context: nil).size.height
  58. }
  59. // MARK: - URL允许的字符
  60. var urlEscaped: String {
  61. return self.addingPercentEncoding(withAllowedCharacters: .urlHostAllowed)!
  62. }
  63. // MARK:- 获取字符串的CGSize
  64. func getSize(with fontSize: CGFloat) -> CGSize {
  65. let str = self as NSString
  66. let size = CGSize(width: UIScreen.main.bounds.width, height: CGFloat(MAXFLOAT))
  67. return str.boundingRect(with: size, options: .usesLineFragmentOrigin, attributes: [NSAttributedString.Key.font: UIFont.systemFont(ofSize: fontSize)], context: nil).size
  68. }
  69. // MARK:- 获取文本图片
  70. func getTextImage(_ size:CGSize,textColor tColor:UIColor,backColor bColor:UIColor,textFont tFont:UIFont) -> UIImage? {
  71. let label = UILabel(frame: CGRect(origin:CGPoint(x:0,y:0), size: size))
  72. label.textAlignment = .center
  73. label.textColor = tColor
  74. label.font = tFont
  75. label.text = self
  76. label.backgroundColor = bColor
  77. UIGraphicsBeginImageContextWithOptions(label.frame.size, true, 0)
  78. guard let context = UIGraphicsGetCurrentContext() else { return nil }
  79. label.layer.render(in: context)
  80. let image = UIGraphicsGetImageFromCurrentImageContext()
  81. UIGraphicsEndImageContext()
  82. return image
  83. }
  84. subscript(r: Range<Int>) -> String {
  85. get {
  86. let startIndex = self.index(self.startIndex, offsetBy: r.lowerBound)
  87. let endIndex = self.index(self.startIndex, offsetBy: r.upperBound)
  88. return String(self[startIndex..<endIndex])
  89. }
  90. }
  91. subscript(r: ClosedRange<Int>) -> String {
  92. get {
  93. let startIndex = self.index(self.startIndex, offsetBy: r.lowerBound)
  94. let endIndex = self.index(self.startIndex, offsetBy: r.upperBound)
  95. return String(self[startIndex...endIndex])
  96. }
  97. }
  98. static func randomString(length:Int) -> String {
  99. let charSet = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
  100. var c = charSet.map { String($0) }
  101. var s:String = ""
  102. for _ in (1...length) {
  103. s.append(c[Int(arc4random()) % c.count])
  104. }
  105. return s
  106. }
  107. }