답변:
swift는 객체 지향 (그리고 배열은 객체가 아닌 구조체입니다)보다 기능면에서 더 뛰어나므로 "find"함수를 사용하여 배열에서 작동하여 선택적 값을 반환하므로 nil 값을 처리 할 준비를하십시오.
let arr:Array = ["a","b","c"]
find(arr, "c")! // 2
find(arr, "d") // nil
Swift 2.0 업데이트 :
find
Swift 2.0에서는 이전 기능이 더 이상 지원되지 않습니다!
Swift 2.0을 Array
사용하면 CollectionType
( Array
구현) 확장에 정의 된 함수를 사용하여 요소의 색인을 찾을 수 있습니다 .
let arr = ["a","b","c"]
let indexOfA = arr.indexOf("a") // 0
let indexOfB = arr.indexOf("b") // 1
let indexOfD = arr.indexOf("d") // nil
또한 술어를 충족시키는 배열에서 첫 번째 요소를 찾는 것은 다음과 같은 또 다른 확장으로 지원됩니다 CollectionType
.
let arr2 = [1,2,3,4,5,6,7,8,9,10]
let indexOfFirstGreaterThanFive = arr2.indexOf({$0 > 5}) // 5
let indexOfFirstGreaterThanOneHundred = arr2.indexOf({$0 > 100}) // nil
이 두 함수 find
는 이전 과 마찬가지로 선택적 값을 반환합니다 .
스위프트 3.0 업데이트 :
indexOf의 구문이 변경되었습니다. 준수하는 항목의 Equatable
경우 다음을 사용할 수 있습니다.
let indexOfA = arr.index(of: "a")
이 방법에 대한 자세한 설명서는 https://developer.apple.com/reference/swift/array/1689674-index 에서 찾을 수 있습니다.
준수하지 않는 배열 항목의 Equatable
경우 index(where:)
다음 을 사용해야합니다 .
let index = cells.index(where: { (item) -> Bool in
item.foo == 42 // test if this is the item you're looking for
})
Swift 4.2 업데이트 :
스위프트 4.2으로, index
더 이상 사용되지 않고로 분리 firstIndex
하고 lastIndex
보다 명확한 설명. 따라서 항목의 첫 번째 인덱스 또는 마지막 인덱스를 찾고 있는지에 따라
let arr = ["a","b","c","a"]
let indexOfA = arr.firstIndex(of: "a") // 0
let indexOfB = arr.lastIndex(of: "a") // 3
indexOf
직접 정의한 구조체를 사용 하는 경우 구조체는 Equatable
프로토콜 을 준수해야 합니다.
tl; dr :
수업의 경우 다음을 찾고있을 수 있습니다.
let index = someArray.firstIndex{$0 === someObject}
전체 답변 :
참조 유형 ( class
)을 사용하면 ID 비교 를 수행 할 수 있다고 언급 할 가치가 있다고 생각합니다 .이 경우 ===
술어 클로저에서 ID 연산자 를 사용해야합니다 .
스위프트 5, 스위프트 4.2 :
let person1 = Person(name: "John")
let person2 = Person(name: "Sue")
let person3 = Person(name: "Maria")
let person4 = Person(name: "Loner")
let people = [person1, person2, person3]
let indexOfPerson1 = people.firstIndex{$0 === person1} // 0
let indexOfPerson2 = people.firstIndex{$0 === person2} // 1
let indexOfPerson3 = people.firstIndex{$0 === person3} // 2
let indexOfPerson4 = people.firstIndex{$0 === person4} // nil
위 구문은 후행 닫기 구문을 사용하며 다음과 같습니다.
let indexOfPerson1 = people.firstIndex(where: {$0 === person1})
스위프트 4 / 스위프트 3-호출되는 함수 index
스위프트 2-호출 된 함수 indexOf
* 구현 하는 유형 에 대해 paulbailey 의 관련적이고 유용한 의견 에 주목하십시오 . 여기서 ( identity operator) 또는 ( equality operator)를 사용하여 비교해야하는지 고려해야합니다 . 를 사용하여 일치하기로 결정한 경우 다른 사람이 제안한 방법 ( ) 만 사용하면됩니다 .class
Equatable
===
==
==
people.firstIndex(of: person1)
Person
구현 된 Equatable
프로토콜을, 이것은 필요하지 않을 것입니다.
Binary operator '===' cannot be applied to operands of type '_' and 'Post'
, Post
내 구조는 ... 어떤 생각입니까?
structs
(및 enums
)는 참조 유형이 아닌 값 유형입니다. 참조 유형 (예 :) 만 class
ID 비교 논리 ( ===
)를 갖습니다 . 무엇을 해야할지에 대한 다른 답변을 확인하십시오 structs
(기본적으로 단순히 array.index(of: myStruct)
유형을 myStruct
준수 하는지 확인하십시오 Equatable
( ==
)).
filter
클로저 가 있는 배열은 다음과 같습니다.
var myList = [1, 2, 3, 4]
var filtered = myList.filter { $0 == 3 } // <= returns [3]
그리고 당신은 배열을 셀 수 있습니다 :
filtered.count // <= returns 1
그래서 당신은 확인할 수 있는 경우 배열이 결합하여 요소를 포함 :
myList.filter { $0 == 3 }.count > 0 // <= returns true if the array includes 3
당신이 위치를 찾고 싶다면 멋진 방법을 보지 못하지만 확실히 다음과 같이 할 수 있습니다.
var found: Int? // <= will hold the index if it was found, or else will be nil
for i in (0..x.count) {
if x[i] == 3 {
found = i
}
}
편집하다
우리가 그 동안, 재미있는 운동 Array
을 위해 find
방법 을 갖도록 확장합시다 .
extension Array {
func find(includedElement: T -> Bool) -> Int? {
for (idx, element) in enumerate(self) {
if includedElement(element) {
return idx
}
}
return nil
}
}
이제 우리는 이것을 할 수 있습니다 :
myList.find { $0 == 3 }
// returns the index position of 3 or nil if not found
Array
하는 find
메소드 를 갖도록 내장 을 확장하는 또 다른 예제를 추가했습니다 . 이것이 좋은 방법인지는 아직 모르겠지만 깔끔한 실험입니다.
enumerate
할 때 더 이상 적용되지 않도록 사용 하도록 수정 했지만 절대적으로 옳습니다.
indexOf()
완벽하게 작동 하지만 하나의 인덱스 만 반환합니다.
조건을 만족시키는 요소에 대한 인덱스 배열을 얻는 우아한 방법을 찾고있었습니다.
수행 방법은 다음과 같습니다.
스위프트 3 :
let array = ["apple", "dog", "log"]
let indexes = array.enumerated().filter {
$0.element.contains("og")
}.map{$0.offset}
print(indexes)
스위프트 2 :
let array = ["apple", "dog", "log"]
let indexes = array.enumerate().filter {
$0.element.containsString("og")
}.map{$0.index}
print(indexes)
사용자 정의 클래스의 경우 Equatable 프로토콜을 구현해야합니다.
import Foundation
func ==(l: MyClass, r: MyClass) -> Bool {
return l.id == r.id
}
class MyClass: Equtable {
init(id: String) {
self.msgID = id
}
let msgID: String
}
let item = MyClass(3)
let itemList = [MyClass(1), MyClass(2), item]
let idx = itemList.indexOf(item)
printl(idx)
스위프트 2 업데이트 :
sequence.contains (element) : 주어진 시퀀스 (예 : 배열)에 지정된 요소가 포함되어 있으면 true를 반환합니다.
스위프트 1 :
요소가 배열 안에 포함되어 있는지 확인하려는 경우 즉, 부울 표시기를 얻으려면 contains(sequence, element)
대신 다음을 사용하십시오 find(array, element)
.
contains (sequence, element) : 주어진 시퀀스 (예 : 배열)에 지정된 요소가 포함되어 있으면 true를 반환합니다.
아래 예를 참조하십시오.
var languages = ["Swift", "Objective-C"]
contains(languages, "Swift") == true
contains(languages, "Java") == false
contains([29, 85, 42, 96, 75], 42) == true
if (contains(languages, "Swift")) {
// Use contains in these cases, instead of find.
}
스위프트 4. 배열에 [String : AnyObject] 유형의 요소가 포함 된 경우. 따라서 요소의 색인을 찾으려면 아래 코드를 사용하십시오.
var array = [[String: AnyObject]]()// Save your data in array
let objectAtZero = array[0] // get first object
let index = (self.array as NSArray).index(of: objectAtZero)
또는 Dictionary의 키를 기준으로 색인을 찾으려면. 여기 배열에는 Model 클래스의 객체가 포함되어 있으며 id 속성과 일치합니다.
let userId = 20
if let index = array.index(where: { (dict) -> Bool in
return dict.id == userId // Will found index of matched id
}) {
print("Index found")
}
OR
let storeId = Int(surveyCurrent.store_id) // Accessing model key value
indexArrUpTo = self.arrEarnUpTo.index { Int($0.store_id) == storeId }! // Array contains models and finding specific one
스위프트 2.1
var array = ["0","1","2","3"]
if let index = array.indexOf("1") {
array.removeAtIndex(index)
}
print(array) // ["0","2","3"]
스위프트 3
var array = ["0","1","2","3"]
if let index = array.index(of: "1") {
array.remove(at: index)
}
array.remove(at: 1)
let array
? 의 사용 self
도 의심 스럽다.
에서 스위프트 4 당신이 당신의 DataModel이 배열을 통해 통과하는 경우, 방법을 우 = 좌변을 구현, Equatable 의정서 확인 데이터 모델에 부합 함을 선언을하고, 그런 다음에야 당신은 '의 (있는 .index "를 사용할 수 있습니다. 예를 들어
class Photo : Equatable{
var imageURL: URL?
init(imageURL: URL){
self.imageURL = imageURL
}
static func == (lhs: Photo, rhs: Photo) -> Bool{
return lhs.imageURL == rhs.imageURL
}
}
그리고,
let index = self.photos.index(of: aPhoto)
Swift 2 (Xcode 7 사용) Array
에는 프로토콜에서 indexOf
제공 하는 방법이 포함되어 CollectionType
있습니다. 실제로 두 가지 indexOf
방법 , 즉 하나는 인수를 일치시키기 위해 동등을 사용하고 다른 하나 는 클로저를 사용합니다.
Swift 2 이전에는 컬렉션과 같은 일반 유형에서 파생 된 구체적인 유형 (예 : 배열)에 대한 메소드를 제공 할 방법이 없었습니다. Swift 1.x에서 "index of"는 전역 함수입니다 ... 그리고 Swift 1.x에서도 전역 함수의 이름이 바뀌 었습니다 find
.
... 또는 Swift 표준 라이브러리에 해당하지 않는 Foundation의 다른 고급 검색 indexOfObject
방법 NSArray
중 하나 의 방법 을 사용할 수도 있습니다 (필수는 아님) . 그냥 import Foundation
(또는 이적으로 재단을 가져 또 다른 모듈), 당신의 캐스팅 Array
에 NSArray
, 당신은에 많은 검색 방법을 사용할 수 있습니다 NSArray
.
함수 라이브러리 Dollar를 사용하여 http://www.dollarswift.org/#indexof-indexof 와 같은 배열에서 indexOf를 수행 할 수도 있습니다
$.indexOf([1, 2, 3, 1, 2, 3], value: 2)
=> 1
여전히 Swift 1.x에서 작업중인 경우
그런 다음 시도하십시오
let testArray = ["A","B","C"]
let indexOfA = find(testArray, "A")
let indexOfB = find(testArray, "B")
let indexOfC = find(testArray, "C")
스위프트 4
cardButtons라는 배열의 숫자를 cardNumber에 저장한다고 가정하면 다음과 같이 할 수 있습니다.
let cardNumber = cardButtons.index(of: sender)
발신자는 버튼 이름입니다.
에 대한 (>= swift 4.0)
오히려 매우 간단합니다. 다음 Array
목표를 고려하십시오 .
var names: [String] = ["jack", "rose", "jill"]
element의 인덱스를 얻으려면 다음 rose
을 수행하면됩니다.
names.index(of: "rose") // returns 1
노트 :
Array.index(of:)
을 반환합니다 Optional<Int>
.
nil
요소가 배열에 존재하지 않음을 의미합니다.
반환 된 값을 강제로 줄 바꿈 해제하거나 또는 if-let
옵션을 사용하여 돌아올 수 있습니다 .