草庐IT

Python:用argparse模块解析命令行选项

全部标签

ruby - 如何在 Sinatra 中制作模块化助手

我想在一个模块中创建一个方法(出于分组原因),它可以作为module.method调用,如下所示:helpersdomoduleUserSessiondeflogged_in?notsession[:email].nil?enddeflogout!session[:email]=nilendendend但是当我尝试使用UserSession.logged_in?调用它时,它说logged_in不是UserSession的方法undefinedmethod`logged_in?'forUserSession:Module当我将方法移动为UserSession的方法时:helpersdom

ruby - 如何选择要在 Ruby 中动态包含的模块版本?

我正在编写一个使用fileutils的小型Rub​​y命令行应用程序来自文件操作的标准库。根据用户调用应用程序的方式,我想包括FileUtils,FileUtils::DryRun或FileUtils::Verbose.自include虽然是私有(private)的,但我无法将选择逻辑放入对象的initialize中方法。(这是我的第一个想法,从那时起我就可以将有关用户选择的信息作为参数传递给new。)我想出了两个似乎可行的选项,但我对其中任何一个都不满意:根据用户的选择在应用程序的命名空间中设置一个全局变量,然后在类中执行条件包含:classWorkercaseApp::OPTION

ruby-on-rails - 覆盖由同一模块中的类方法定义的 ActiveSupport::Concern 模块中的方法

我有一个ActiveSupport::Concern模块,大致如下所示:moduleMyModelmoduleAcceptanceextendActiveSupport::Concernincludeddoenumstatus:[:declined,:accepted]enddefdeclined!self.status=:declined#someextralogicself.save!enddefaccepted!self.status=:accepted#someextralogicself.save!endendend这只会被包含到ActiveRecord类中,因此使用enum

ruby - 如何解析 CSV 文件,更新字段,然后保存

我需要读取一个CSV文件,更新一个字段,然后保存更改。除了将我的更改保存到我正在更新的字段外,我一切正常:require'csv'@parsed_file=CSV::Reader.parse(File.open("#{RAILS_ROOT}/doc/some.csv"))@parsed_file.each_with_indexdo|row,x|address=row[5]l=Location.address_find(address)ifl!=nilputs"#{l.name}at#{l.address}"row[14]=l.store_codeputsrow[14]elseputs"

ruby - 模块化、基于组件的 Sinatra 应用程序的架构

我正在开发一个包含大约10个不同功能组件的Sinatra应用程序。我们希望能够将这些组件混合并匹配到应用程序的单独实例中,完全从config.yaml文件配置,如下所示:components:-route:'/chunky'component_type:FoodListercomponent_settings:food_type:baconmax_items:400-route:'places/paris'component_type:Mappercomponent_settings:latitude:48.85387273165654longitude:2.340087890625-

ruby-on-rails - RubyMine 中未解析的 ruby​​ 引用

有什么方法可以避免在RubyMineIDE中出现“未解析的ruby​​引用”警告?例如,当我的View中的某些代码调用View助手的方法时,即使代码有效,我也会收到“未解析的ruby​​引用”警告。上述案例只是众多案例中的一个。另一个例子是使用RSpec时:it"shouldrequireanemail"dono_email_user=User.new(@attr.merge(:email=>""))no_email_user.should_notbe_validendRubyMineIDE不知道参数“be_valid”。我的问题是-有什么办法可以解决这个问题吗?我应该需要额外的文件吗

ruby - 我如何使用 Ruby 来解析时间,就像它在我指定的时区中一样,时区格式为 America/Los_Angeles?

我希望能够从Ruby(1.8.7)中的字符串解析时间,其中该字符串不包含任何时区信息。我想将字符串视为处于以这种格式指定的多个时区中的任何一个:'America/New_York'。时间字符串示例:'2010-02-0501:00:01'我花了很长时间试图解决这个问题。我确实找到了一个类似的问题,但它的答案不适用于我的情况:HowdoIgetRubytoparsetimeasifitwereinadifferenttimezone?上述解决方案的问题是我的时区不能全部以Time.parse(http://www.ruby-doc.org/stdlib-1.8.7/libdoc/time

ruby - 如何在光标上指定无超时选项?

这个问题在这里已经有了答案:tailablecursorinmongodbtimingout(1个回答)关闭9年前。如何在游标上指定一个无超时选项?我可以从我的笔记本电脑上手动运行该作业,但服务器上发生了一些事情并且我一直收到此错误:游标xxx的MONGODBcursor.refresh()查询响应返回CURSOR_NOT_FOUND。指定的游标无效,或者游标在服务器上可能已超时。MONGODBcursor.refresh()forcursoryyy作业从ruby​​调度程序文件运行,并在rake中指定为命名空间rake在中间调用了另一个ruby​​模块,作业在这个模块执行期间结束了我

ruby - 动态模块 : Querying tables with secondary index

我正在使用gemaws-sdk-ruby查询看起来像这样的表:hk(Hashkey)|guid(Rangekey)|Timestamp(SecondaryRangeindex)|otherattributesaaaa|50|2013-02-04T12:33:00Z|aaaa|244|2013-04-22T04:54:00Z|aaaa|342|2013-05-18T06:52:00Z|bbbb|243|2013-06-21T13:17:00Z|我想要做的是获取在特定日期之后创建的所有“aaaa”行。例如:AWS.config(access_key_id:'xxx',secret_acce

ruby - 当我在终端中打开一个新选项卡时,RVM 不读取 .ruby-gemset 文件

我在Fedora20上新安装了RVM。如果我cd到myapp,RVM将读取.ruby-gemset文件并切换到适当的gemset,但是如果我打开一个新选项卡(control-shift-t)并运行rvmgemsetlist我发现它正在使用默认的gemset。有人知道我可能做错了什么吗?我在.bashrc中有以下内容#.bashrc#Sourceglobaldefinitionsif[-f/etc/bashrc];then./etc/bashrcfiPATH=$PATH:$HOME/.local/bin:$HOME/bin:$HOME/.rvm/binexportPATH[[-s"$HO