jjzjj

proc-open

全部标签

ruby-on-rails - 来自 Rails Heroku 的 Facebook Open Graph

我一整天都在与这个问题作斗争,真的需要一些意见。我有一个在HerokuCedar上运行的Rails应用程序(3.1.3),试图使用gemfb_graph(2.4.0)发布一些FacebookOpenGraph操作。这是我的代码。beginapp=FbGraph::Application.new(ENV['facebook_app_id'])me=FbGraph::User.me(user.facebook_access_token)logger.info"Facebook:User#{user.name}reviewinggame#{game_url(review.game)}"act

ruby - 在 Ruby 中使用关键字参数柯里化(Currying) proc

假设我有一个通用的Proc、Lambda或method,它带有一个可选的第二个参数:pow=->(base,exp:2){base**exp}现在我想柯里化(Currying)这个函数,给它一个3的exp。cube=pow.curry.call(exp:3)这里有一个歧义,由关键字参数和新的散列语法引起,Ruby将exp:3解释为作为第一个参数传递的散列,base.这导致函数立即被调用,当#**被发送到散列时呈现NoMethodError。为第一个参数设置默认值同样会导致函数在柯里化(Currying)时立即被调用,如果我将第一个参数标记为必需,而不提供默认值:pow=->(base:

ruby - 在 proc 中设置全局

我一直在努力更好地理解Ruby,但我遇到了一些问题:$SAFE=1puts$SAFE#1proc{$SAFE=2puts$SAFE#2}.callputs$SAFE#1以上代码部分取自eRB的源代码并重写以更好地突出示例。基本上在proc中,可以将$SAFE的值设置为任何想要的值,并且在proc之后,SAFE的值返回到它在proc之前的值。如果我不使用单词$SAFE,而是将其更改为不同的单词,例如$DOOR:$DOOR=1puts$DOORproc{$DOOR=2puts$DOOR}.callputs$DOOR那么$DOOR在proc之后的值是2而不是1。为什么两个例子有区别?

ruby - 在 ruby​​ 中将类方法转换为 proc 的惯用方法

假设我想使用Proc描述Kernel.puts。我该怎么做?我能想到很多可能性;Proc.newdo|*args|Kernel.puts*argsend:puts.to_proc.curry[Kernel]#doesn'twork,returns`nil`asputsisvarargs但是两者都非常冗长。 最佳答案 method是您要找的吗?它可以让您将方法保存到变量。2.1.0:003>m=Kernel.method(:puts)=>#2.1.0:004>m.call('hi')hi

Ruby 1.9 - 没有这样的文件可以加载 'win32/open3'

我在Windows上运行ruby​​1.9.2并试图移植在Ruby1.8中工作的代码。该代码使用以前运行良好的Open4.popen4。对于1.9.2,我做了以下事情:通过geminstallPOpen4安装了POpen4需要POpen4通过require'popen4'尝试像这样使用POpen4:Open4.popen4("cmd"){|io_in,io_out,io_er|...}当我这样做时,我得到了错误:nosuchfiletoload--win32/open3如果我尝试安装win32-open3(geminstallwin32-open3),我会收到错误消息:win32-op

ruby - 在符号上链接 & to_proc

Rubyist众所周知,&会在符号上调用to_proc,所以[:a,:b,:c].map(&:to_s)相当于[:a,:b,:c].map{|e|e.to_s}#=>["a","b","c"]假设我想在to_s之后立即调用另一个方法,这两个实现将起作用:[:a,:b,:c].map{|e|e.to_s.upcase}[:a,:b,:c].map(&:to_s).map(&:upcase)我的问题是,有没有一种方法可以将&Symbol#to_proc调用链接到一个参数中?像这样的东西:[:a,:b,:c].map(&:to_s:upcase)谢谢! 最佳答案

ruby - 为什么 Ruby 需要 .call 来调用 Proc?

我只是想知道在Ruby中必须使用proc.call(args)调用Proc是否有任何充分的理由甚至优势,这使得更高-order函数语法更冗长且更不直观。为什么不只是proc(args)?为什么要区分函数、lambda和block?基本上,它们都是一样的,那么为什么要使用这种令人困惑的语法呢?或者有什么我没有意识到的意义吗? 最佳答案 您需要一些方法来区分调用Proc和传递它。在Python和ECMAScript中,这很简单:有括号就是调用,没有括号就不是。在Ruby中,省略括号也是一个调用,因此,必须有一些其他方式来区分。在Ruby

ruby - 在 ruby​​ 中,file.readlines.each 并不比 file.open.each_line 快,为什么?

只是为了分析我的iis日志(奖励:碰巧知道iislog是用ASCII编码的,errrr..)这是我的ruby代码1.readlinesDir.glob("*.log").eachdo|filename|File.readlines(filename,:encoding=>"ASCII").eachdo|line|#commentlineifline[0]=='#'nextelseline_content=line.downcase#justcareaboutfirstonematched_keyword=keywords.select{|e|line_content.include?e

ruby-on-rails - Ruby:强制 open-uri 返回 IPv4 地址

在我们的Rails应用中,我们有一个ControllerAction,它打开一个外部URL,并将它作为JSON返回给我们的前端使用。今天,我收到以下错误:Errno::EAFNOSUPPORT:协议(protocol)不支持地址族-socket(2)我们的开发人员建议,如果地址同时返回IPv6响应和IPv4响应,这就是错误。我们不支持IPv6,所以这可以解释它。这是触发请求的方法:defmedline_responseopen("http://apps.nlm.nih.gov/medlineplus/services/mpconnect_service.cfm?mainSearchCr

ruby-on-rails - Rails 日志文件 "not opened for writing"

我正在将我的应用程序从ruby​​1.8.7迁移到1.9.3(然后升级Rails)。但是我在登录1.9.3时遇到了一些问题。通过在控制台或服务器启动时在environment.rb中使用以下代码logfile=File.open(File.join(RAILS_ROOT,'/log/call_log.log'),'a')CALL_LOGGER=AuditLogger.new(logfile)CALL_LOGGER.info"CALL_LOGGER:Serverstarted."我明白了/usr/local/rvm/scripts/irbrc.rb:32:in`write':notope