草庐IT

根据条件返回不同列

全部标签

Ruby:如何遍历哈希数组并在单个字符串中返回值?

抱歉,如果这很明显,我只是不明白。如果我有一个哈希数组,例如:people=[{:name=>"Bob",:occupation=>"Builder"},{:name=>"Jim",:occupation=>"Coder"}]我想遍历数组并输出字符串,例如:“Bob:Builder”。我该怎么做?我知道如何迭代,但我还是有点迷茫。现在,我有:people.eachdo|person|person.eachdo|k,v|puts"#{v}"endend我的问题是我不明白如何返回两个值,只分别返回每个值。我错过了什么?感谢您的帮助。 最佳答案

ruby - 为什么 [].all?{|a| a.包括? ('_' )} 返回真?

为什么[].all?{|a|a.include?('_')}返回true? 最佳答案 您的代码询问以下语句的真实性:“对于空列表中的所有元素a,a包含字符'_'。”因为空列表中没有元素,所以该语句为真。(这在逻辑上称为vacuoustruth。)如果您改为尝试找到一种使该表达式为假的方法,可能会更容易理解。这需要在空列表中至少有一个元素不包含'_'。但是,空列表是空的,因此不存在这样的元素。因此,该陈述不能有意义地为假,因此它必须为真。 关于ruby-为什么[].all?{|a|a.包括

sql - 如何在 rails 中添加条件 where 子句

我是一名Rails新手,我正在尝试使用Rails对表执行搜索,而我只是使用我的sql知识来执行此操作。但这看起来不像是rails或ruby​​...有没有更好的方法来做我在下面做的事情?(基本上,如果日期参数已填充,则只将日期参数传递给sql)defsearch(begin_date=nil,end_date=nil)subject="andcreated_at"if!(begin_date.nil?||end_date.nil?)where_part=subject+"BETWEEN:begin_dateAND:end_date"elseif(begin_date.nil?&&end

sql - PostgreSQL 条件 where 子句

在我的RubyonRails应用程序中,我使用的是blazer(https://github.com/ankane/blazer)并且我有以下sql查询:SELECT*FROMsurvey_resultssrLEFTJOINclientscONc.id=sr.client_idWHEREsr.client_id={client_id}这个查询非常有效。但是我需要添加条件逻辑来检查client_id变量是否存在。如果是,那么我将按此变量进行过滤,如果不是,则我不会启动此where子句。我如何在PostgreSQL中执行此操作? 最佳答案

ruby-on-rails - 使用从ruby中的方法返回的散列在一行中分配多个变量

我有一个返回散列映射{:name=>"Test",:desc=>"TestDescription}的方法。它将始终返回:name和:description。如何用返回的哈希分配2个变量。我可以这样做,但它会调用该方法两次:@name,@desc=get_name_desc_map[:name],get_name_desc_map[:desc]我只想调用一次该方法。 最佳答案 使用Ruby的并行赋值非常简单:@name,@desc=get_name_desc_map.values另一种方法是(如果您不知道原始散列中键的顺序):@nam

ruby-on-rails - 如何将条件 "IS NOT NULL"添加到 Thinking Sphinx 搜索中

我正在使用ThinkingSphinx进行全文搜索,关注thisvideo.我想做以下事情:@articles=Article.search(params[:search],:conditions=>"published_atISNOTNULL",:order=>:created_at)问题是这行不通。搜索方法似乎只接受散列条件。我尝试了几种方法,但我对如何将“published_atISNOTNULL”表示为哈希一无所知... 最佳答案 在Railscasts给出了解决方案Ifyouwant*all*resultsforthatm

ruby-on-rails - 有没有办法在一行中有条件地添加到数组?

我有str1和str2。str1可能是也可能不是空字符串,我想构造一个数组,如下所示:str1=""str2="bar"["bar"]或str1="foo"str2="bar"["foo","bar"]我现在只能想出一种在两条线上执行此操作的方法,但我知道必须有一种方法可以在一条线上执行此操作。 最佳答案 在ruby1.9中[*(str1unlessstr1.empty?),str2]在ruby1.8中[(str1unlessstr1.empty?),str2].compact 关于ru

ruby-on-rails - 混合 ActiveRecord 查找条件

我想根据created_on>=somedateANDnameINsomelistofnames的组合查找记录。对于“>=”,我必须使用sql条件。对于“IN”,我必须使用条件散列,其中键是:name,值是名称数组。有没有办法将两者结合起来? 最佳答案 您可以在rails2.1及更高版本中使用命名作用域ClassTest"created_on>2005-01-01"named_scope:named_fred,:conditions=>{:name=>"fred"}end那么你可以做Test.created_after_2005.n

ruby-on-rails - cucumber 测试失败,返回 `stream closed (IOError)`

我们目前正在将我们的Rails应用程序升级到Rails4。在3.2中,我们的Cucumber(1.3.17)测试运行良好(如果可悲地缓慢),使用Capybara(2.4.4)、Poltergeist(1.5.1)和PhantomJS(1.9.8)引擎盖下。但是在4.0.12和4.1.8中,我们在运行中的随机点得到一个streamclosed(IOError):streamclosed(IOError)/var/lib/jenkins/.rvm/gems/ruby-2.1.5@tallama-integration/gems/cucumber-1.3.17/lib/cucumber/fo

ruby - 我可以在 Ruby 中获取 'ensure' 内的返回值吗?

defsome_methodputs'inmethod'return'Iamareturnvalue'ensureputs'willprintattheend'#CanIsomehowgetthereturnvalueofsome_methodhere?end是否有一些(可能是元编程)原则/方法来获取“确保”子句内方法的返回值,该子句是方法定义的一部分(我们都知道无论如何都会执行)? 最佳答案 分配一个变量只是让你的返回值成为一个变量。您可以在ensure语句中使用该变量,但该方法的返回值将是该方法的非异常部分中评估的最后一条语句。