【发布时间】:2017-09-13 14:56:44
【问题描述】:
我有两个实体:
议程活动
议程日期
AgendaDates 与 AgendaEvents 是一对多的关系。
我正在尝试存储在一个临时数组中 (var myTempEvents = [AgendaEvent] ()) 所有 AgendaEvents 在 AgendaDates 中都有一个等于定义日期的日期(让 myDate = Date() )
到目前为止,我有这个:
var myEventDate = [String]()
var myTempEvents = [AgendaEvent]()
var myEvents = [AgendaEvent]()
var myDate = Date()
func getEventDates() {
for event in myEvents {
for date in (event.agendaDates as? Set<AgendaDate>)! {
let eventDates = date.agendaDates
eventDate = eventDates
formatter.dateFormat = "dd MM yyyy"
let eventDateString = formatter.string(from: eventDate)
myEventDate.append(eventDateString)
}
}
}
我现在需要做的是检查 AgendaEvents 的日期是否等于 myDate,如果是,我需要将该事件添加到 myTempEvents。
这应该发生在这个函数内部:
func configureCell(cell: CalendarAgendaCell, indexPath: IndexPath) {
for dates in calendar.selectedDates {
for dateOfEvent in myEventDate {
formatter.dateFormat = "dd MM yyyy"
let dateToCompare = formatter.string(from: dates)
if dateOfEvent == dateToCompare {
let myEvent = myTempEvents[indexPath.row]
cell.configureCell(agendaEvent: myEvent)
} else {
//empty the tempArray
}
}
}
}
这个函数是由tableView的cellForRowAt函数调用的:
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
// Dequeue Cell
let cell = tableView.dequeueReusableCell(withIdentifier: "AgendaCell", for: indexPath) as! AgendaCell
//Fetch model object to display
configureCell(cell: cell, indexPath: indexPath)
return cell
}
我不太擅长核心数据(仍在学习),因此非常感谢任何帮助。
谢谢!
更新------14/09/17
正如@Simo 所建议的那样,我已经像这样编辑了我的代码:
func agendaEventsWithDate(date: Date) -> NSFetchRequest<NSFetchRequestResult>
{
// create a fetch request that will retrieve all the AgendaEvents.
let fetchRequest = NSFetchRequest<NSFetchRequestResult>(entityName: "AgendaEvent")
// set the predicate to only keep AgendaEvents where the related AgendaDate's date matches the passed in date.
fetchRequest.predicate = NSPredicate(format: "ANY agendaDates.agendaDates == %@", date as CVarArg)
return fetchRequest
}
let myTempEvents = try?context.fetch(agendaEventsWithDate(date: Date()))
上下文在哪里:
let ad = UIApplication.shared.delegate as! AppDelegate
让上下文 = ad.persistentContainer.viewContext
但是我得到了这个错误:
'fetch' 的模糊使用
谢谢!
【问题讨论】: