Szukam sposobu na zamianę postaci w jerzyku String
.
Przykład: „To jest mój ciąg”
Chciałbym zamienić „” na „+”, aby otrzymać „This + is + my + string”.
Jak mogę to osiągnąć?
Szukam sposobu na zamianę postaci w jerzyku String
.
Przykład: „To jest mój ciąg”
Chciałbym zamienić „” na „+”, aby otrzymać „This + is + my + string”.
Jak mogę to osiągnąć?
Odpowiedzi:
Ta odpowiedź została zaktualizowana dla Swift 4 i 5 . Jeśli nadal używasz Swift 1, 2 lub 3, zobacz historię zmian.
Masz kilka opcji. Możesz zrobić zgodnie z sugestią @jaumard i użyćreplacingOccurrences()
let aString = "This is my string"
let newString = aString.replacingOccurrences(of: " ", with: "+", options: .literal, range: nil)
Jak zauważono poniżej przez @cprcrack, parametry options
i range
są opcjonalne, więc jeśli nie chcesz określać opcji porównywania ciągów lub zakresu w celu wykonania zamiany, potrzebujesz tylko następujących elementów.
let aString = "This is my string"
let newString = aString.replacingOccurrences(of: " ", with: "+")
Lub, jeśli dane mają określony format, taki jak ten, w którym właśnie zastępujesz znaki separacji, możesz użyć, components()
aby rozbić ciąg na i tablicę, a następnie możesz użyć join()
funkcji, aby połączyć je z powrotem z określonym separatorem .
let toArray = aString.components(separatedBy: " ")
let backToString = toArray.joined(separator: "+")
Lub jeśli szukasz bardziej Swifty rozwiązania, które nie korzysta z API z NSString, możesz to wykorzystać.
let aString = "Some search text"
let replaced = String(aString.map {
$0 == " " ? "+" : $0
})
"x86_64"
a nowe mapowanie wygląda"Optional([\"x\", \"8\", \"6\", \"_\", \"6\", \"4\"])"
stringByReplacingOccurrencesOfString
w Swift 2, musi import Foundation
mieć możliwość korzystania z tej metody.
Możesz użyć tego:
let s = "This is my string"
let modified = s.replace(" ", withString:"+")
Jeśli dodasz tę metodę rozszerzenia w dowolnym miejscu w kodzie:
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)
}
}
Rozwiązanie Swift 3, Swift 4, Swift 5
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: "+")
Używam tego rozszerzenia:
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: "")
}
}
Stosowanie:
let token = "<34353 43434>"
token.replaceCharacters("< >", toString:"+")
Rozwiązanie Swift 3 na wzór Sunkasa:
extension String {
mutating func replace(_ originalString:String, with newString:String) {
self = self.replacingOccurrences(of: originalString, with: newString)
}
}
Posługiwać się:
var string = "foo!"
string.replace("!", with: "?")
print(string)
Wynik:
foo?
Kategoria, która modyfikuje istniejący zmienny ciąg:
extension String
{
mutating func replace(originalString:String, withString newString:String)
{
let replacedString = self.stringByReplacingOccurrencesOfString(originalString, withString: newString, options: nil, range: nil)
self = replacedString
}
}
Posługiwać się:
name.replace(" ", withString: "+")
Rozwiązanie Swift 3 oparte na odpowiedzi Ramisa :
extension String {
func withReplacedCharacters(_ characters: String, by separator: String) -> String {
let characterSet = CharacterSet(charactersIn: characters)
return components(separatedBy: characterSet).joined(separator: separator)
}
}
Próbowałem wymyślić odpowiednią nazwę funkcji zgodnie z konwencją nazewnictwa Swift 3.
Mniej mi się przydarzyło, chcę tylko zmienić (słowo lub znak) w String
Więc korzystam z Dictionary
extension String{
func replace(_ dictionary: [String: String]) -> String{
var result = String()
var i = -1
for (of , with): (String, String)in dictionary{
i += 1
if i<1{
result = self.replacingOccurrences(of: of, with: with)
}else{
result = result.replacingOccurrences(of: of, with: with)
}
}
return result
}
}
stosowanie
let mobile = "+1 (800) 444-9999"
let dictionary = ["+": "00", " ": "", "(": "", ")": "", "-": ""]
let mobileResult = mobile.replace(dictionary)
print(mobileResult) // 001800444999
replace
var str = "This is my string"
str = str.replacingOccurrences(of: " ", with: "+")
print(str)
replacingOccurrences
w String
?
Myślę, że Regex to najbardziej elastyczny i solidny sposób:
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"
Szybkie rozszerzenie:
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
}
}
Idź dalej i używaj go jak let replacedString = yorString.stringByReplacing(replaceStrings: [" ","?","."], with: "+")
Szybkość funkcji jest czymś, z czego nie mogę się pochwalić, ale możesz przekazać tablicę String
w jednym przejściu, aby wykonać więcej niż jedną zamianę.
Oto przykład Swift 3:
var stringToReplace = "This my string"
if let range = stringToReplace.range(of: "my") {
stringToReplace?.replaceSubrange(range, with: "your")
}
Xcode 11 • Swift 5.1
Metodę mutacji StringProtocol replacingOccurrences
można zaimplementować w następujący sposób:
extension RangeReplaceableCollection where Self: StringProtocol {
mutating func replaceOccurrences<Target: StringProtocol, Replacement: StringProtocol>(of target: Target, with replacement: Replacement, options: String.CompareOptions = [], range searchRange: Range<String.Index>? = nil) {
self = .init(replacingOccurrences(of: target, with: replacement, options: options, range: searchRange))
}
}
var name = "This is my string"
name.replaceOccurrences(of: " ", with: "+")
print(name) // "This+is+my+string\n"
Jeśli nie chcesz używać NSString
metod Objective-C , możesz po prostu użyć split
i join
:
var string = "This is my string"
string = join("+", split(string, isSeparator: { $0 == " " }))
split(string, isSeparator: { $0 == " " })
zwraca tablicę ciągów ( ["This", "is", "my", "string"]
).
join
łączy się te elementy z A +
, w wyniku pożądaną wydajność: "This+is+my+string"
.
możesz to przetestować:
niech newString = test.stringByReplacingOccurrencesOfString („”, withString: „+”, opcje: zero, zakres: zero)
Oto rozszerzenie metody zastępowania wystąpień w miejscu String
, która nie eliminuje zbędnej kopii i robi wszystko na swoim miejscu:
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
}
}
(Podpis metody naśladuje również podpis wbudowanej String.replacingOccurrences()
metody)
Można użyć w następujący sposób:
var string = "this is a string"
string.replaceOccurrences(of: " ", with: "_")
print(string) // "this_is_a_string"