0

服务器端执行 SQL 查询(服务器是用 python 编写的)返回一个 json,如下所示:

return HttpResponse(json.dumps([{"data":output, "total":theResult}]), content_type ='application/json')

output是内部方法的结果返回,并且已经像这样序列化:

output = serializers.serialize('json',p_list,fields=('price','publishdate','size'))

客户端成功接收响应,success:^(AFHTTPRequestOperation *operation, id responseObject)使用AFHTTPRequestOperationManager这就是responseObject调试控制台中的样子(lldb)

po responseObject
<__NSCFArray 0x116fa6190>(
{
    data = "[{\"pk\": 817, \"model\": \"xx\", \"fields\": { \"price\": \"3300\", \"publishdate\": \"2014-10-30T00:00:00\", \"size\": 35}}, {\"pk\": 2799, \"model\": \"xx\", \"fields\": { \"price\": \"6250\", \"publishdate\": \"2014-12-08T00:00:00\",\"size\": 0}}]";
    total =     (
       381
    );
}
)

在控制台中po responseObject[0][@"data"][0]打印数据数组并按p responseObject[0][@"total"][0]预期打印 381

问题:

  1. 在试图转换responseObject[0][@"total"][0]为整数的代码中返回一个垃圾号
  2. 强制responseObject[0][@"data"][0]转换NSArray*然后尝试执行计数或任何其他操作会导致异常:'NSInvalidArgumentException', reason: '-[__NSCFString count]: unrecognized selector sent to instance
4

1 回答 1

0

部分问题可能是描述方法没有引用所有字符串,因此 381 可能是一个字符串。

可能的解决方案(缺少 OP 代码):

如果真的int有用:

int value = responseObject[0][@"total"][0] 

如果它真的是string

NSString *valueString = responseObject[0][@"total"][0] 
int value = [valueString intValue];
于 2015-01-22T16:40:53.163 回答