W1116 String Functions
Swift is a new programming language developed by Apple for use with iOS and OS X development. One of the things that makes Swift so unique is its focus on safety. Because of this, it doesn't have as many functions as Objective-C, but those that it does have are more powerful. This article highlights some of those string functions from Apple's API documentation for String.
You must remember, however, that the language itself is not fully released and so this article, and the corresponding code examples may change in future releases of Swift.
You can concatenate strings in Swift with the addition operator (+). In its most basic form, you can simply add two strings together to make one string:
let myString = "I am" + " awesome." //myString is equal to "I am awesome."
This is nice and simple but it's not extremely useful. What if you want to take a string and add some numbers? Or what if you have multiple parts to your string that need concatenating together? Well for this Swift has provided an alternative, named concatenation operator (&+). This works much like the addition operator except instead of appending the second operand (the number corresponding to String ) to the end of the first operand (the string), it will create a new string out of the two.
There is no limit to how many strings you can concatenate in this way, so it only makes sense that there are functions that are similar to the addition (+) and concatenation (&+) operators, called string-append and string-insert. These work on any number of strings at once, appending them together on an element-by-element basis.
Swift also provides functions for determining the equality between two strings, checking if one string is greater than another and also checking if one exists in another. These are useful when you want to make sure that user input matches up with what your application expects.
String comparisons in Swift are made with the case-sensitive equal to the operator (==), the not equal to operator (!=), and using ranges with the contains property.
Here are some examples of what these operators do:
Accessing Characters by Index
You can access individual characters in a String using the index of the character, with indexes starting from 0. This is done with a method called
This method returns a single Character object, so bear that in mind if you need to do any sort of comparisons on it--it won't be a simple boolean value. An example of this is as follows:
Accessing String Length
You can get the length of a String by using its length property. This is simply an integer, not an actual character count (it includes all spaces and punctuation too). Here's an example:
Remember that when you do this, it will include all punctuation and extra whitespace.
Finding Position of Substring Within a String
You can use the index of a string to search for the position of another string inside it. This is done with the
range(of:) method which returns an optional integer, with nil meaning that the substring was not found.
This method can be very useful when you want to find out where a string occurs in another string. It will also let you know if it was not found in the string, which can be important.
Appending Strings Together
Swift provides three methods for appending strings together:
append(string), appendContentsOf(_:) and join()
The first method, append(string), will simply add another String to the end of the receiver String. Like with concatenation, this method takes one string as an argument.
Here's how it is used:
The second two methods are similar to the first, taking a function with a String type as its sole argument.
The difference is that the first argument to these functions is another String, which will be added to the receiver string. For example:
While this may seem like an unnecessary repetition of effort, it can make your code easier to read by not having to reference your constant string variable constantly.
Inserting Strings into Other Strings
You can insert a String into another String using the (insert:) method. This inserts the string to be inserted anywhere in the receiver string and inserts nothing if the insertion point is outside of its limits.
Here's an example:
Note that this doesn't have any effect on the length of the string--it does not grow to accommodate itself. It also takes an optional argument atIndex: which specifies where in the receiver String it should be inserted. If you omit the argument, it finds its own insertion point by looking at the beginning or end of the string.
Replacing Substrings in Strings
You can replace all occurrences of a substring inside a string with another String using the (replacingOccurrencesOf:) method. This method is very useful when you need to make multiple changes in one go. Here's an example:
This method will replace all occurrences of the string in the argument with another string in its receiver. This is very useful if you want to replace certain terms (or even misspellings) in your code, but only one at a time.
Removing Substrings from Strings
You can remove a substring from a string by using the (removingSubrangeOfString:) method. This takes a String as an argument and then deletes that string from the receiver string, wherever it appears. For example:
With this method, unlike the (replacingOccurrencesOf:) method, you must specify where in the string it should be removed. Also note that if you remove a substring that doesn't exist in the string, this method does nothing.
You can remove an entire String from a string using the (removingRangeOfString:) method. This also takes a String as its argument, but then deletes that string from the receiver string wherever it appears, and then returns a new string with the deleted contents.
You can change the case of a string by using its
(uppercaseString)properties. These return another String, with the receiver's contents in lower- or uppercase respectively.
These two properties can be useful for things like converting user input or capitalizing words in a sentence. They do not mutate the original string; instead, they return a new one.
String functions in Swift are very useful and can help you get a lot of work done with little effort. It's good to become familiar with all of these methods, particularly the ones that remove portions of strings. That way, you can quickly get the contents you want without needing to create a whole new string. String functions are also useful if you need to change certain words in your code depending on context- for example, turning "item" into "items."
The thing to take away is that Swift is a very versatile language. Most of the functions that are available in Objective-C are also available here, just with different syntax and functionality. String functions are one example of this, but there are many others as well.