source

Swift 4에서 String 하위 문자열을 사용하려면 어떻게 해야 합니까? 'substring(to:)'은 더 이상 사용되지 않습니다.문자열 슬라이싱 첨자를 '부분 범위 from' 연산자와 함께 사용하십시오.

nicesource 2023. 5. 9. 22:48
반응형

Swift 4에서 String 하위 문자열을 사용하려면 어떻게 해야 합니까? 'substring(to:)'은 더 이상 사용되지 않습니다.문자열 슬라이싱 첨자를 '부분 범위 from' 연산자와 함께 사용하십시오.

Swift 3으로 작성된 간단한 코드는 다음과 같습니다.

let str = "Hello, playground"
let index = str.index(of: ",")!
let newStr = str.substring(to: index)

Xcode 9 베타 5에서 다음과 같은 경고가 표시됩니다.

'substring(to:)더 이상 사용되지 않습니다.이용해주세요String'slicking range from' 연산자를 사용하여 첨자를 자릅니다.

스위프트 4에서 부분 범위의 슬라이싱 첨자를 어떻게 사용할 수 있습니까?

한쪽 면을 비워 두어야 하므로 "부분 범위"라는 이름이 지정됩니다.

let newStr = str[..<index]

연산자의 부분 범위도 마찬가지입니다. 다른 쪽은 비워 두십시오.

let newStr = str[index...]

이 범위 연산자는 다음을 반환합니다.Substring문자열로 변환하려면 다음을 사용합니다.String의 초기화 기능:

let newStr = String(str[..<index])

새로운 서브스트링에 대한 자세한 내용은 여기를 참조하십시오.

서브스트링(스위프트 3)을 스트링 슬라이싱(스위프트 4)으로 변환

Swift 3, 4의 예:

let newStr = str.substring(to: index) // Swift 3
let newStr = String(str[..<index]) // Swift 4

let newStr = str.substring(from: index) // Swift 3
let newStr = String(str[index...]) // Swift 4 

let range = firstIndex..<secondIndex // If you have a range
let newStr = = str.substring(with: range) // Swift 3
let newStr = String(str[range])  // Swift 4

스위프트 5, 4

사용.

let text = "Hello world"
text[0] // H
text[...3] // "Hell"
text[6..<text.count] // world
text[NSRange(location: 6, length: 3)] // wor

코드

import Foundation

public extension String {
  subscript(value: Int) -> Character {
    self[index(at: value)]
  }
}

public extension String {
  subscript(value: NSRange) -> Substring {
    self[value.lowerBound..<value.upperBound]
  }
}

public extension String {
  subscript(value: CountableClosedRange<Int>) -> Substring {
    self[index(at: value.lowerBound)...index(at: value.upperBound)]
  }

  subscript(value: CountableRange<Int>) -> Substring {
    self[index(at: value.lowerBound)..<index(at: value.upperBound)]
  }

  subscript(value: PartialRangeUpTo<Int>) -> Substring {
    self[..<index(at: value.upperBound)]
  }

  subscript(value: PartialRangeThrough<Int>) -> Substring {
    self[...index(at: value.upperBound)]
  }

  subscript(value: PartialRangeFrom<Int>) -> Substring {
    self[index(at: value.lowerBound)...]
  }
}

private extension String {
  func index(at offset: Int) -> String.Index {
    index(startIndex, offsetBy: offset)
  }
}

Swift 4/5에서 단축:

let string = "123456"
let firstThree = String(string.prefix(3)) //"123"
let lastThree = String(string.suffix(3)) //"456"

스위프트5

(Java의 하위 문자열 방법):

extension String {
    func subString(from: Int, to: Int) -> String {
       let startIndex = self.index(self.startIndex, offsetBy: from)
       let endIndex = self.index(self.startIndex, offsetBy: to)
       return String(self[startIndex..<endIndex])
    }
}

용도:

var str = "Hello, Nick Michaels"
print(str.subString(from:7,to:20))
// print Nick Michaels

코드를 Swift 4로 변환하는 방법은 다음과 같습니다.

let str = "Hello, playground"
let index = str.index(of: ",")!
let substr = str.prefix(upTo: index)

아래 코드를 사용하여 새 문자열을 만들 수 있습니다.

let newString = String(str.prefix(upTo: index))

하위 문자열(: 인덱스에서) [index...]로 변환됨

샘플 확인

let text = "1234567890"
let index = text.index(text.startIndex, offsetBy: 3)

text.substring(from: index) // "4567890"   [Swift 3]
String(text[index...])      // "4567890"   [Swift 4]

몇 가지 유용한 확장 기능:

extension String {
    func substring(from: Int, to: Int) -> String {
        let start = index(startIndex, offsetBy: from)
        let end = index(start, offsetBy: to - from)
        return String(self[start ..< end])
    }

    func substring(range: NSRange) -> String {
        return substring(from: range.lowerBound, to: range.upperBound)
    }
}

의 예uppercasedFirstCharacterSwift3 및 Swift4의 편의 시설.

소유물uppercasedFirstCharacterNewSwift4에서 문자열 슬라이싱 첨자를 사용하는 방법을 보여 줍니다.

extension String {

   public var uppercasedFirstCharacterOld: String {
      if characters.count > 0 {
         let splitIndex = index(after: startIndex)
         let firstCharacter = substring(to: splitIndex).uppercased()
         let sentence = substring(from: splitIndex)
         return firstCharacter + sentence
      } else {
         return self
      }
   }

   public var uppercasedFirstCharacterNew: String {
      if characters.count > 0 {
         let splitIndex = index(after: startIndex)
         let firstCharacter = self[..<splitIndex].uppercased()
         let sentence = self[splitIndex...]
         return firstCharacter + sentence
      } else {
         return self
      }
   }
}

let lorem = "lorem".uppercasedFirstCharacterOld
print(lorem) // Prints "Lorem"

let ipsum = "ipsum".uppercasedFirstCharacterNew
print(ipsum) // Prints "Ipsum"

다음과 같이 String 클래스에 대한 확장을 사용하여 사용자 지정 subString 메서드를 만들 수 있습니다.

extension String {
    func subString(startIndex: Int, endIndex: Int) -> String {
        let end = (endIndex - self.count) + 1
        let indexStartOfText = self.index(self.startIndex, offsetBy: startIndex)
        let indexEndOfText = self.index(self.endIndex, offsetBy: end)
        let substring = self[indexStartOfText..<indexEndOfText]
        return String(substring)
    }
}

Swift 4를 사용하여 String에서 SubString(접두사 및 접미사) 만들기:

let str : String = "ilike"
for i in 0...str.count {
    let index = str.index(str.startIndex, offsetBy: i) // String.Index
    let prefix = str[..<index] // String.SubSequence
    let suffix = str[index...] // String.SubSequence
    print("prefix \(prefix), suffix : \(suffix)")
}

산출량

prefix , suffix : ilike
prefix i, suffix : like
prefix il, suffix : ike
prefix ili, suffix : ke
prefix ilik, suffix : e
prefix ilike, suffix : 

두 인덱스 사이에 부분 문자열을 생성하려면 다음을 사용합니다.

let substring1 = string[startIndex...endIndex] // including endIndex
let subString2 = string[startIndex..<endIndex] // excluding endIndex

'String: subString:'을 대체할 문자열 확장자를 작성했습니다.

extension String {
    
    func sliceByCharacter(from: Character, to: Character) -> String? {
        let fromIndex = self.index(self.index(of: from)!, offsetBy: 1)
        let toIndex = self.index(self.index(of: to)!, offsetBy: -1)
        return String(self[fromIndex...toIndex])
    }
    
    func sliceByString(from:String, to:String) -> String? {
        //From - startIndex
        var range = self.range(of: from)
        let subString = String(self[range!.upperBound...])
        
        //To - endIndex
        range = subString.range(of: to)
        return String(subString[..<range!.lowerBound])
    }
    
}

용도:"Date(1511508780012+0530)".sliceByString(from: "(", to: "+")

결과: "1511508780012"

PS: 옵션은 강제로 포장을 벗깁니다.필요한 경우 Type safety check를 추가하십시오.

특정 문자까지 하위 문자열을 가져오려는 경우 먼저 인덱스를 찾을 필요가 없으며, 다음을 사용할 수 있습니다.prefix(while:)방법

let str = "Hello, playground"
let subString = str.prefix { $0 != "," } // "Hello" as a String.SubSequence

프로그래밍을 할 때 저는 종종 플레인 A-Za-z와 0-9만 있는 문자열을 가지고 있습니다.어려운 색인 작업이 필요 없습니다.이 확장은 일반적인 기존의 왼쪽/중간/오른쪽 기능을 기반으로 합니다.

extension String {

    // LEFT
    // Returns the specified number of chars from the left of the string
    // let str = "Hello"
    // print(str.left(3))         // Hel
    func left(_ to: Int) -> String {
        return "\(self[..<self.index(startIndex, offsetBy: to)])"
    }

    // RIGHT
    // Returns the specified number of chars from the right of the string
    // let str = "Hello"
    // print(str.left(3))         // llo
    func right(_ from: Int) -> String {
        return "\(self[self.index(startIndex, offsetBy: self.length-from)...])"
    }

    // MID
    // Returns the specified number of chars from the startpoint of the string
    // let str = "Hello"
    // print(str.left(2,amount: 2))         // ll
    func mid(_ from: Int, amount: Int) -> String {
        let x = "\(self[self.index(startIndex, offsetBy: from)...])"
        return x.left(amount)
    }
}

이것이 조금 더 도움이 되기를 바랍니다 :-

var string = "123456789"

특정 인덱스 뒤에 하위 문자열을 지정하려는 경우.

var indexStart  =  string.index(after: string.startIndex )// you can use any index in place of startIndex
var strIndexStart   = String (string[indexStart...])//23456789

끝에 있는 문자열을 제거한 후 하위 문자열을 원할 경우.

var indexEnd  =  string.index(before: string.endIndex)
var strIndexEnd   = String (string[..<indexEnd])//12345678

다음 코드로 인덱스를 만들 수도 있습니다.

var  indexWithOffset =  string.index(string.startIndex, offsetBy: 4)

이 방법을 사용하면 특정 범위의 문자열을 얻을 수 있습니다.시작 색인을 통과한 후 원하는 총 문자 수를 입력해야 합니다.

extension String{
    func substring(fromIndex : Int,count : Int) -> String{
        let startIndex = self.index(self.startIndex, offsetBy: fromIndex)
        let endIndex = self.index(self.startIndex, offsetBy: fromIndex + count)
        let range = startIndex..<endIndex
        return String(self[range])
    }
}

이것이 제 해결책입니다. 경고도 없고 오류도 없지만 완벽합니다.

let redStr: String = String(trimmStr[String.Index.init(encodedOffset: 0)..<String.Index.init(encodedOffset: 2)])
let greenStr: String = String(trimmStr[String.Index.init(encodedOffset: 3)..<String.Index.init(encodedOffset: 4)])
let blueStr: String = String(trimmStr[String.Index.init(encodedOffset: 5)..<String.Index.init(encodedOffset: 6)])
var str = "Hello, playground"
let indexcut = str.firstIndex(of: ",")
print(String(str[..<indexcut!]))
print(String(str[indexcut!...]))

당신은 이런 방법으로 시도할 수 있고 적절한 결과를 얻을 수 있습니다.

제가 사용하는 간단한 방법은 다음과 같습니다.

String(Array(str)[2...4])

스위프트 4, 5, 5+

마지막에서 부분 문자열

let str = "Hello World"
let removeFirstSix = String(str.dropFirst(6))
print(removeFirstSix) //World

첫 번째에서 하위 문자열

let removeLastSix = String(str.dropLast(6))
print(removeLastSix) //Hello

도움이 되길 바랍니다.

extension String {
    func getSubString(_ char: Character) -> String {
        var subString = ""
        for eachChar in self {
            if eachChar == char {
                return subString
            } else {
                subString += String(eachChar)
            }
        }
        return subString
    }
}


let str: String = "Hello, playground"
print(str.getSubString(","))

언급URL : https://stackoverflow.com/questions/45562662/how-can-i-use-string-substring-in-swift-4-substringto-is-deprecated-pleas

반응형