티스토리 뷰
1. Multiline String Literals
swift 는 여러 줄의 String 을 """ 기호를 사용하여 표현할 수 있으며, 닫는 따옴표들이 어디에 위치하는 지에 따라 indent 또한 편리하게 설정할 수가 있다.
let wiseWords = """
this
is
multi
lines
String
"""
print(wiseWords)
// this
// is
// multi
// lines
// String
let wiseWords = """
this
is
multi
lines
String
"""
print(wiseWords)
//this
//is
//multi
//lines
//String
Multiline String 내에서 줄바꿈을 하지만 출력 값에는 줄바꿈이 없어야 할 때는 \ 를 사용하여 해당 라인을 이어줄 수 있다.
let softWrappedQuotation = """
The White Rabbit put on his spectacles. "Where shall I begin, \
please your Majesty?" he asked.
"Begin at the beginning," the King said gravely, "and go on \
till you come to the end; then stop."
"""
print(softWrappedQuotation)
//The White Rabbit put on his spectacles. "Where shall I begin, please your Majesty?" he asked.
//
//"Begin at the beginning," the King said gravely, "and go on till you come to the end; then stop."
2. Initializing an Empty String
"" 으로 String 변수를 초기화할 수도 있지만, 아래와 같이 초기화할 수 있다.
var emptyString = "" // empty string literal
var anotherEmptyString = String() // initializer syntax
// these two strings are both empty, and are equivalent to each other
위 두 변수는 구조적으로 동일한 빈 값을 가지고 있다.
if emptyString.isEmpty {
print("Nothing to see here")
}
// Prints "Nothing to see here"
isEmpty 함수로 확인 가능하다.
3. Working with Characters
String Value 는 character 타입으로 아래와 같이 접근할 수 있다.
for character in "Dog!🐶" {
print(character)
}
// D
// o
// g
// !
// 🐶
혹은 Character type annotaion 을 사용하여 아래와 같이 하나의 Character를 선언하거나 배열을 사용하여 String으로 나타낼 수 있다.
let exclamationMark: Character = "!"
let catCharacters: [Character] = ["C", "a", "t", "!", "🐱"]
let catString = String(catCharacters)
print(catString)
// Prints "Cat!🐱"
4. Unicode
\u{ } 를 사용하여 유니코드에 있는 모든 Character를 사용할 수 있다.
let eAcute: Character = "\u{E9}" // é
let combinedEAcute: Character = "\u{65}\u{301}" // e followed by ́
// eAcute is é, combinedEAcute is é
5. Counting Characters
String.count 를 사용하여 문자열을 카운트할 수 있다.
let unusualMenagerie = "Koala 🐨, Snail 🐌, Penguin 🐧, Dromedary 🐪"
print("unusualMenagerie has \(unusualMenagerie.count) characters")
// Prints "unusualMenagerie has 40 characters"
6. Accessing and Modifying a String
문자열도 배열과 마찬가지로 index로 접근할 수 있다. 아래 예제로 쭉 확인해보자.
let greeting = "Guten Tag!"
greeting[greeting.startIndex]
// G
greeting[greeting.index(before: greeting.endIndex)]
// !
greeting[greeting.index(after: greeting.startIndex)]
// u
let index = greeting.index(greeting.startIndex, offsetBy: 7)
greeting[index]
// a
또한 indices 프로퍼티를 사용하여 아래와 같이 모든 index에 접근할 수 있다.
for index in greeting.indices {
print("\(greeting[index]) ", terminator: "")
}
// Prints "G u t e n T a g ! "
insert 함수와 remove 함수로 문자열을 조작할 수 있으며, insert(_:at:)와 insert(contentsOf:at:)로 오버로딩 되어 있기 때문에 아래아 같이 character 가 아닌 String 값을 삽입할 때는 contentsOf: 로 사용하여야 한다.
var welcome = "hello"
welcome.insert("!", at: welcome.endIndex)
// welcome now equals "hello!"
print(welcome)
welcome.insert(contentsOf: " there", at: welcome.index(before: welcome.endIndex))
// welcome now equals "hello there!"
print(welcome)
remove 작업도 동일하게 remove() 함수를 사용하여 하나의 character를 지울 수 있으며, removeSubrange(range) 를 사용하여 index 범위로 string 을 지울 수 있다.
var welcome = "hello there!"
welcome.remove(at: welcome.index(before: welcome.endIndex))
print(welcome)
let range = welcome.index(welcome.endIndex, offsetBy: -6)..<welcome.endIndex
welcome.removeSubrange(range)
print(welcomea)
//hello there
//hello
7. Substrings
문자열의 부분을 추출하기 위해서는 range 변수와 String 배열을 활용하면 된다.
let greeting = "Hello, world!"
let index = greeting.firstIndex(of: ",") ?? greeting.endIndex
let beginning = greeting[..<index]
print(beginning)
let newString = String(beginning)
print(newString)
//Hello
//Hello
8. Prefix and Suffix Equality
hasPrefix와 hasSuffix 함수를 사용하면, 문자열의 시작, 끝 부분을 비교하여 결과를 확인할 수 있다.
let romeoAndJuliet = [
"Act 1 Scene 1: Verona, A public place",
"Act 1 Scene 2: Capulet's mansion",
"Act 1 Scene 3: A room in Capulet's mansion",
"Act 1 Scene 4: A street outside Capulet's mansion",
"Act 1 Scene 5: The Great Hall in Capulet's mansion",
"Act 2 Scene 1: Outside Capulet's mansion",
"Act 2 Scene 2: Capulet's orchard",
"Act 2 Scene 3: Outside Friar Lawrence's cell",
"Act 2 Scene 4: A street in Verona",
"Act 2 Scene 5: Capulet's mansion",
"Act 2 Scene 6: Friar Lawrence's cell"
]
var act1SceneCount = 0
for scene in romeoAndJuliet {
if scene.hasPrefix("Act 1") {
act1SceneCount += 1
}
}
print("There are \(act1SceneCount) scenes in Act 1")
//There are 5 scenes in Act 1
var mansionCount = 0
var cellCount = 0
for scene in romeoAndJuliet {
if scene.hasSuffix("Capulet's mansion") {
mansionCount += 1
} else if scene.hasSuffix("Friar Lawrence's cell") {
cellCount += 1
}
}
print("\(mansionCount) mansion scenes; \(cellCount) cell scenes")
// Prints "6 mansion scenes; 2 cell scenes"
'Mobile > ios' 카테고리의 다른 글
[ios] swift 기본 문법 정리 6: Closures (0) | 2022.11.29 |
---|---|
[ios] swift 기본 문법 정리 5: Function (0) | 2022.11.28 |
[ios] swift 기본 문법 정리 4: Collection Types (0) | 2022.11.23 |
[ios] swift 기본 문법 정리 2: Control Flow (0) | 2022.11.23 |
[ios] swift 기본 문법 정리 1: Basic (0) | 2022.11.23 |
- await
- 정보보안기사 #실기 #정리
- react-native
- 이탈리안 레스토랑
- javascript
- redux
- 맛집
- 인천 구월동 맛집
- AsyncStorage
- Async
- react
- 인천 구월동 이탈리안 맛집
- 파니노구스토
- redux-thunk
- Promise
- Total
- Today
- Yesterday