0

我正在使用 Facebook API 来提取我所有朋友的列表。但是,我不想将结果存储在数据库中。我只想获取我返回的结果哈希并对结果执行选择。

但是,我很难做到这一点......

我得到这样的结果......

[{"name"=>"John Smith", "id"=>"12345"}, {"name"=>"Jane Doe", "id"=>"23456"}, {"name"=>"Samuel Jackson", "id"=>"34567"}, {"name"=>"Kate Upton", "id"=>"45678"}]

它们存储在@friends

我的选择是:

@friends.select{|key, hash| hash["name"] == "John Smith" }

但我不断收到错误“nil:NilClass 的未定义方法 `[]'”

两个问题: 1. 如何让哈希搜索返回 John Smith(不存储在数据库中,并且不修改初始 Facebook API 查询) 2. 是否可以使用“Like”而不是“==”以便它返回包含单词的结果?

谢谢!

4

1 回答 1

1

你得到"undefined method [] for nil:NilClass"是因为你错误地使用了方法选择。尝试这样做:

 @friends.select{ |hash| hash["name"] == "John Smith" }

所以我相信这回答了你的第一个问题。您不需要在数据库中存储任何内容,而是在实例变量中存储任何内容@friends,并正确使用 select。

关于第二个问题,我相信你应该研究正则表达式,因为它真的取决于你所说的“喜欢”是什么意思,但如果你说你想要:

它返回包含单词的结果?

好吧,如果你想检查一个特定的词(比如说Smith),你可以这样选择:

@friends.select{ |hash| hash["name"].include? "Smith" }

这将为您提供数组中名称中包含Smith一词的所有元素。

于 2012-07-04T23:01:03.990 回答