我有一个从JSON数据创建的模型对象数组。 我有数千条记录包含重复项,需要删除这些记录。 如果记录具有相同的"名称"和相同的"地址"属性,则将其视为重复记录。
问题是,我知道如何删除重复对象的唯一方法是在 for 循环搜索中执行 for 循环,我想知道是否有更好、更有效的方法? 我认为最好的方法是使用"filter"方法,但我很难将其配置为使用包含具有多个属性的模型对象的数组。
我的模型对象如下所示:
struct Person {
let id: Int
let name: String
let address: String
init(id:Int, name:String, address:String) {
self.id = id
self.name = name
self.address = address
}
}
我尝试在我的模型对象数组上使用过滤器方法的方式如下所示(我知道这不起作用(:
let uniqueArray = peopleArray.filter { $0.name == $1.name, $0.address == $1.address }
谁能看出我做错了什么?
1:你需要让你的结构符合平等协议
func ==(lhs: Person, rhs: Person) -> Bool {
return lhs.name == rhs.name && lhs.address == rhs.address
}
2:您可以使用集合来控制要从数组中过滤哪些对象,但您需要使结构符合 Hashable 协议,向其添加 hashValue 属性。
struct Person: Equatable, Hashable {
let id: Int
let name: String
let address: String
init(id: Int, name: String, address: String) {
self.id = id
self.name = name
self.address = address
}
var hashValue: Int {
return name.hashValue ^ address.hashValue
}
}
3:用法
let people = [Person(id: 1, name: "Name A", address: "Address A"),
Person(id: 2, name: "Name B", address: "Address B"),
Person(id: 2, name: "Name B", address: "Address B"),
Person(id: 3, name: "Name C", address: "Address C")]
// Will keep the order
var set: Set<Person> = []
let orderedset = people.filter{ set.insert($0).inserted }
print(orderedset)
// Will not keep the order
let unique = Set<Person>(people)
print(unique)
提示:
如果ID
是唯一的,则应使用它进行比较。