首先:新年快乐:-)
我想要做什么
我试图在核心数据中划分两个属性,然后计算这些划分的平均值。属性由关键路径(例如,、、eur
)usd
指定aud
。
示例: 我有以下数据集:
date eur usd aud
------------------------------
2010-01-01 0.5 1.0 1.5
2010-01-02 0.6 1.1 1.6
2010-01-03 0.4 1.0 1.3
除以两个属性,例如 eur / usd 与以下结果...
divide eur / usd:
------------------
2010-01-01 0.5
2010-01-02 0.54
2010-01-03 0.4
...然后计算这些数字的平均值(0.5 + 0.54 + 0.4)/3 = 0.48
我的代码
由于我想让这些计算直接由 Core Data 执行,我创建了以下表达式并获取请求:
NSExpression *fromCurrencyPathExpression = [NSExpression
expressionForKeyPath:fromCurrency.lowercaseString];
NSExpression *toCurrencyPathExpression = [NSExpression
expressionForKeyPath:toCurrency.lowercaseString];
NSExpression *divisionExpression = [NSExpression
expressionForFunction:@"divide:by:"
arguments:@[fromCurrencyPathExpression,
toCurrencyPathExpression]];
NSExpression *averageExpression = [NSExpression expressionForFunction:@"average:"
arguments:@[divisionExpression]];
NSString *expressionName = @"averageRate";
NSExpressionDescription *expressionDescription =
[[NSExpressionDescription alloc] init];
expressionDescription.name = expressionName;
expressionDescription.expression = averageExpression;
expressionDescription.expressionResultType= NSDoubleAttributeType;
NSFetchRequest *request = [NSFetchRequest
fetchRequestWithEntityName:NSStringFromClass([self class])];
NSPredicate *predicate =
[NSPredicate predicateWithFormat:@"date >= %@ AND date <= %@",startDate,fiscalPeriod.endDate];
request.predicate = predicate;
request.propertiesToFetch = @[expressionDescription];
request.resultType = NSDictionaryResultType;
NSError *error;
NSArray *results = [context
executeFetchRequest:request error:&error];
问题
但是,在运行应用程序时,它会崩溃并显示错误消息:
Unsupported argument to sum : (
"eur / usd"
我的代码有什么问题?如何链接这两个计算并让它们直接在 Core Data 中执行?
谢谢!