Любой способ заменить символы в Swift String?

377

Я ищу способ заменить символы в Swift String.

Пример: "This is my string"

Я хотел бы заменить на +, чтобы получить: "This+is+my+string".

Как я могу это достичь?

Теги:
string

16 ответов

725
Лучший ответ

Этот ответ был обновлен для Swift 4. Если вы все еще используете Swift 1, 2 или 3, просмотрите историю изменений.

У вас есть несколько вариантов. Вы можете сделать так, как предложил @jaumard, и использовать replacecingOccurferences replacingOccurrences()

let aString = "This is my string"
let newString = aString.replacingOccurrences(of: " ", with: "+", options: .literal, range: nil)

И, как отмечает @cprcrack ниже, options и параметры range являются необязательными, поэтому, если вы не хотите указывать параметры сравнения строк или диапазон для выполнения замены внутри, вам нужно только следующее.

let aString = "This is my string"
let newString = aString.replacingOccurrences(of: " ", with: "+")

Или, если данные находятся в определенном формате, подобном этому, где вы просто заменяете разделительные символы, вы можете использовать components() чтобы разбить строку и массив, а затем вы можете использовать функцию join() чтобы вернуть их обратно. вместе с указанным разделителем.

let toArray = aString.components(separatedBy: " ")
let backToString = toArray.joined(separator: "+")

Или, если вы ищете более простое решение Swifty, которое не использует API из NSString, вы можете использовать это.

let aString = "Some search text"

let replaced = String(aString.map {
    $0 == " " ? "+" : $0
})
  • 9
    параметры и параметры диапазона являются необязательными
  • 1
    отличная замена swift2 для stringByReplacingOccurferencesOfString
Показать ещё 7 комментариев
57

Вы можете использовать это:

let s = "This is my string"
let modified = s.replace(" ", withString:"+")    

Если вы добавите этот метод расширения в любом месте вашего кода:

extension String
{
    func replace(target: String, withString: String) -> String
    {
       return self.stringByReplacingOccurrencesOfString(target, withString: withString, options: NSStringCompareOptions.LiteralSearch, range: nil)
    }
}

Swift 3:

extension String
{
    func replace(target: String, withString: String) -> String
    {
        return self.replacingOccurrences(of: target, with: withString, options: NSString.CompareOptions.literal, range: nil)
    }
}
43

Swift 3, Swift 4 Solution

let exampleString = "Example string"

//Solution suggested above in Swift 3.0
let stringToArray = exampleString.components(separatedBy: " ")
let stringFromArray = stringToArray.joined(separator: "+")

//Swiftiest solution
let swiftyString = exampleString.replacingOccurrences(of: " ", with: "+")
  • 0
    это ответ на этот вопрос.
18

Вы проверили это:

var test = "This is my string"

let replaced = test.stringByReplacingOccurrencesOfString(" ", withString: "+", options: nil, range: nil)
13

Свифт 4:

let abc = "Hello world"

let result = abc.replacingOccurrences(of: " ", with: "_", 
    options: NSString.CompareOptions.literal, range:nil)

print(result :\(result))

Выход:

result : Hello_world
8

Решение Swift 3 вдоль линий Sunkas's:

extension String {
    mutating func replace(_ originalString:String, with newString:String) {
        self = self.replacingOccurrences(of: originalString, with: newString)
    }
}

Использование:

var string = "foo!"
string.replace("!", with: "?")
print(string)

Вывод:

foo?
7

Я использую это расширение:

extension String {

    func replaceCharacters(characters: String, toSeparator: String) -> String {
        let characterSet = NSCharacterSet(charactersInString: characters)
        let components = self.componentsSeparatedByCharactersInSet(characterSet)
        let result = components.joinWithSeparator("")
        return result
    }

    func wipeCharacters(characters: String) -> String {
        return self.replaceCharacters(characters, toSeparator: "")
    }
}

Использование:

let token = "<34353 43434>"
token.replaceCharacters("< >", toString:"+")
  • 0
    спасибо @Ramis это действительно хорошо работает для меня
5

Категория, которая изменяет существующую изменяемую строку:

extension String
{
    mutating func replace(originalString:String, withString newString:String)
    {
        let replacedString = self.stringByReplacingOccurrencesOfString(originalString, withString: newString, options: nil, range: nil)
        self = replacedString
    }
}

Использование:

name.replace(" ", withString: "+")
3

Решение Swift 3 на основе ответа Рамиса:

extension String {
    func withReplacedCharacters(_ characters: String, by separator: String) -> String {
        let characterSet = CharacterSet(charactersIn: characters)
        return components(separatedBy: characterSet).joined(separator: separator)
    }
}

Пробовал придумать подходящее имя функции в соответствии с соглашением об именах Swift 3.

  • 0
    Это мое предпочтительное решение, поскольку оно позволяет заменять несколько символов одновременно.
1

Вот пример для Swift 3:

var stringToReplace = "This my string"
if let range = stringToReplace.range(of: "my") {
   stringToReplace?.replaceSubrange(range, with: "your")
} 
0

Это легко и быстро. 4.2. просто используйте replacingOccurrences(of: " ", with: "_") для замены

var myStr = "This is my string"
let replaced = myStr.replacingOccurrences(of: " ", with: "_")
print(replaced)
0

Быстрое расширение:

extension String {

    func stringByReplacing(replaceStrings set: [String], with: String) -> String {
        var stringObject = self
        for string in set {
            stringObject = self.stringByReplacingOccurrencesOfString(string, withString: with)
        }
        return stringObject
    }

}

Продолжайте и используйте его как let replacedString = yorString.stringByReplacing(replaceStrings: [" ","?","."], with: "+")

Скорость функции - это то, чем я вряд ли могу гордиться, но вы можете передать массив String за один проход, чтобы сделать несколько замен.

0

Я думаю, что Regex является наиболее гибким и надежным способом:

var str = "This is my string"
let regex = try! NSRegularExpression(pattern: " ", options: [])
let output = regex.stringByReplacingMatchesInString(
    str,
    options: [],
    range: NSRange(location: 0, length: str.characters.count),
    withTemplate: "+"
)
// output: "This+is+my+string"
0

Я реализовал эту очень легкую функциональность:

func convap (text : String) -> String {
    return text.stringByReplacingOccurrencesOfString("'", withString: "''")
}

Итак, вы можете написать:

let sqlQuery = "INSERT INTO myTable (Field1, Field2) VALUES ('\(convap(value1))','\(convap(value2)')
0

Если вы не хотите использовать методы Objective-C NSString, вы можете просто использовать split и join:

var string = "This is my string"
string = join("+", split(string, isSeparator: { $0 == " " }))

split(string, isSeparator: { $0 == " " }) возвращает массив строк (["This", "is", "my", "string"]).

join соединяет эти элементы с a +, что приводит к желаемому результату: "This+is+my+string".

-1

Здесь расширение для метода замены вхождений на месте в String, которое не создает ненужной копии и делает все на месте:

extension String {
    mutating func replaceOccurrences<Target: StringProtocol, Replacement: StringProtocol>(of target: Target, with replacement: Replacement, options: String.CompareOptions = [], locale: Locale? = nil) {
        var range: Range<Index>?
        repeat {
            range = self.range(of: target, options: options, range: range.map { self.index($0.lowerBound, offsetBy: replacement.count)..<self.endIndex }, locale: locale)
            if let range = range {
                self.replaceSubrange(range, with: replacement)
            }
        } while range != nil
    }
}

(Сигнатура метода также имитирует сигнатуру встроенного метода String.replacingOccurrences())

Может использоваться следующим образом:

var string = "this is a string"
string.replaceOccurrences(of: " ", with: "_")
print(string) // "this_is_a_string"
  • 0
    Я обновил код, чтобы предотвратить бесконечные циклы, если содержащийся текст содержался в целевом тексте.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню