草庐IT

document_items

全部标签

ruby - 如何在不使用 HERE-DOCUMENT 语法的情况下在 Ruby 中制作多行字符串文字?

问题总结我想尝试使用Ruby来完成我在Python中所做的事情。在Python中它有r"""syntaxtosupportrawstrings,这很好,因为它允许将原始字符串与代码内联,并以更自然的方式连接它们,而无需特殊缩进。在Ruby中,当使用原始字符串时,必须使用其次是EOT在单独的行中,这会破坏代码布局。你可能会问,为什么不使用Ruby的%q{}?嗯,因为%q{}与Python的r"""相比有局限性因为它不会转义多个\\\并且只处理单个\.我正在动态生成Latex代码并写入一个文件,该文件稍后用pdflatex编译。Latex代码包含类似\\\的内容在许多地方。如果我使用Rub

ruby-on-rails - 冒号前缀和附加之间的区别(:item vs item:)

在ruby​​中追加和前置冒号有什么区别?例子:#Inrailsyouoftenhavethingslikethis:has_many:models,dependent::destroy为什么dependent:有一个冒号,而:models和:destroy有一个冒号?有什么区别? 最佳答案 这是Ruby1.9中的新语法,用于定义散列中作为键的符号。前置和附加的:都定义了一个symbol,但后者仅在散列初始化期间有效。你可以想到一个symbol作为轻量级字符串常量。相当于:dependent=>:destroy在1.9之前,散列是使

ruby 场 : documenting abstract methods implementations

我有一个典型的OO模式:一个基本抽象类(定义抽象方法)和几个以特定于类的方式实现这些抽象方法的类。我习惯于在抽象方法中只编写一次文档,然后它会自动传播到几个具体类(至少它在Javadoc、Scaladoc、Doxygen中按以下方式工作),即我不需要重复所有具体类中的相同描述。但是,我找不到如何在YARD中进行此类传播。我试过,例如:#Somedescriptionofabstractclass.#@abstractclassAbstractClass#Somemethoddescription.#@return[Symbol]somereturndescription#@abstra

ruby-on-rails - Mongoid::Document 是 GlobalID::ActiveJobs 的标识吗?

根据ActiveJobsguide,第8节,它说:ThisworkswithanyclassthatmixesinGlobalID::Identification,whichbydefaulthasbeenmixedintoActiveModelclasses.Mongoid::Document混合ActiveModel::Model,但我找不到GlobalID::Identification在它的included_modules中。GlobalID::Identification在哪里定义?我可以有效地使用任何Mongoid::Document吗?为我的ActiveJobs?

ruby - 背包 : how to add item type to existing solution

我一直在使用动态规划的这种变体来解决背包问题:KnapsackItem=Struct.new(:name,:cost,:value)KnapsackProblem=Struct.new(:items,:max_cost)defdynamic_programming_knapsack(problem)num_items=problem.items.sizeitems=problem.itemsmax_cost=problem.max_costcost_matrix=zeros(num_items,max_cost+1)num_items.timesdo|i|(max_cost+1).ti

ruby-on-rails - rails 3 : validate presence of at least one has many through association item

我有两个模型:Project和ProjectDiscipline:classProject:destroyhas_many:project_disciplines,through::project_disciplinizationsattr_accessible:project_discipline_idsattr_accessible:project_disciplines_attributesaccepts_nested_attributes_for:project_disciplines,:reject_if=>proc{|attributes|attributes['name'

关于Document mapping type name can‘t start with ‘_‘, found: [_update]

在修改elasticsearch时,用_update进行局部修改,修改失败,报错{    "error": {        "root_cause": [            {                "type": "invalid_type_name_exception",                "reason": "Document mapping type name can't start with '_', found: [_update]"            }        ],        "type": "invalid_type_name_exce

ruby - Rspec 有 (n).items 未定义的方法

我正在尝试遵循指南oncode.tuts我不断收到错误消息。这是我的图书馆规范:require'spec_helper'describeLibrarydobefore:alldolib_arr=[Book.new("JavaScript:TheGoodParts","DouglasCrockford",:development),Book.new("DontMakemeThink","SteveKrug",:usability),]File.open"books.yml","w"do|f|f.writeYAML::dumplib_arrendendbefore:eachdo@lib=L

ruby-on-rails - ruby ( rails ): remove whitespace from each array item

Ifoundthiscode:.each_key{|a|self[a].strip!ifself[a].respond_to?:strip!}...但它用于散列,而我正尝试对数组执行相同的操作。 最佳答案 这就是collect的用途。以下处理nil元素,让它们单独存在:yourArray.collect{|e|e?e.strip:e}如果没有nil元素,你可以使用:yourArray.collect(&:strip)...这是以下内容的缩写:yourArray.collect{|e|e.strip}strip!行为类似,但它将已经“

ruby - "self-documenting"代码如何才能不烦人?

关闭。这个问题是opinion-based.它目前不接受答案。想改善这个问题吗?更新问题,以便可以通过editingthispost用事实和引文回答问题.3年前关闭。Improvethisquestion我不确定这里的最佳实践是什么,但我经常看到缩写的变量名,尤其是当范围很小的时候。所以(使用简单的Ruby示例)而不是defadd_location(name,coordinates),我看到类似defadd_loc(name,coord)的东西——我什至可能会看到类似defadd_loc(n,x,y)的东西.我想当人们习惯于看到缩写时,更长的名字可能会让他们感到疲倦。冗长是否有助于可读