草庐IT

mysql - 如果列值不在一组不同列的值中,则 SQL 选择行

全部标签

ruby-on-rails - 在 Rails 中验证之前如何从值中去除美元符号?

这是我在我的模型中使用的:before_validation:strip_dollar_signvalidates:amount_due,:format=>{:with=>/^\d+??(?:\.\d{0,2})?$/},:numericality=>{:greater_than=>0}privatedefstrip_dollar_signself.amount_due=self.amount_due.to_s.tr!('$,','').to_fend如果我在Rails控制台中手动运行来自strip_dollar_sign函数的行,我得到的正是我想要的(即400美元最终为400.0),

ruby - 用 Ruby 正则表达式中的值替换所有匹配项

我在进行Ruby字符串替换时遇到了问题。我正在为我正在使用的有限语言编写一个预处理器,它本身不支持数组,所以我自己动手。我有一条线:x[0]=x[1]&x[1]=x[2]我想用重新格式化的版本替换每个实例:x__0=x__1&x__1=x__2该行可能在别处包含方括号。我有一个匹配数组用途的正则表达式:array_usage=/(\w+)\[(\d+)\]/但我想不出Ruby构造来逐个替换每个实例。我不能使用.gsub()因为它会匹配行中的每个实例,并将每个数组声明替换为第一个声明。.scan()提示说,如果您尝试在block内使用带有.sub()!的扫描,则字符串正在被修改。如有任何

Ruby:是否可以设置实例变量的值,其中实例变量通过字符串命名?

不确定这个模式叫什么,但场景是这样的:classSome#thisclasshasinstancevariablescalled@thing_1,@thing_2etc.end有没有办法设置实例变量的值,其中实例变量名是由字符串创建的?类似于:i=2some.('thing_'+i)=55#setsthevalueofsome.thing_2to55 最佳答案 在Object上搜索“instance_variable”:some.instance_variable_get(("@thing_%d"%2).to_sym)some.in

ruby - 如果 `main` 是 `Object` 的实例,为什么我不能调用它?

当我输入self时,我得到一个返回值main。我做了这个测试:main2=Object.new然后我可以调用main2,它会返回一些东西,但是当我调用main时,它会引发一个undefinedvariable错误。这是怎么发生的?以下是我在其他网站上发现的关于这个顶级环境如何工作的假设:classObjectObject.new.instance_evaldodefself.to_s"main"endprivate###Yourprogramgetsinsertedhere...##endend这对我来说很有意义。 最佳答案 “Wh

ruby - 如何增加散列中未初始化键的值?

如果我尝试增加哈希中尚不存在的键的值,就像这样h=Hash.newh[:ferrets]+=1我收到以下错误:NoMethodError:undefinedmethod`+'fornil:NilClass这对我来说很有意义,而且我知道这一定是一个非常简单的问题,但我在SO上找不到它。如果我什至事先不知道我将拥有哪些key,我该如何添加和递增此类key? 最佳答案 可以在构造函数中设置hash的默认值h=Hash.new(0)h[:ferrets]+=1ph[:ferrets]请注意,设置默认值有一些缺陷,因此您必须谨慎使用。h=Ha

ruby - 如果没有 arg,则针对 stdin 运行的脚本;否则输入文件=ARGV[0]

这工作得很好-只是想知道是否有任何改进来缩短它?if(ARGV[0].nil?)theninput=$ 最佳答案 您可以完全删除前五行。来自镐$因此:print$Kernel.gets是$whiles=getsputssend 关于ruby-如果没有arg,则针对stdin运行的脚本;否则输入文件=ARGV[0],我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/2013428/

ruby - 创建一个临时文件而不在 Ruby 中打开它

有没有办法在不打开临时文件的情况下创建它?我必须运行一个可执行文件,将它的输出重定向到一个文件,然后读取并解析它。tempfile创建的所有内容都已打开,这会触发错误,因为文件已锁定。 最佳答案 你也可以使用Dir::TmpnameDir::Tmpname.create('your_application_prefix'){|path|putspath}路径将包含唯一路径参见https://github.com/ruby/ruby/blob/ruby_1_9_3/lib/tmpdir.rb#L116

ruby-on-rails - 如何获取 ActiveRecord 在 Ruby on Rails 中执行的最后一个 SQL 查询?

我正在寻找类似CodeIgniter的东西:$this->db->last_query();(http://codeigniter.com/user_guide/database/helpers.html) 最佳答案 据我所知,访问查询列表并不容易。尽管如此,您还是可以轻松访问它们,创建一个super简单的记录器。如果您打开ActiveRecord::ConnectionAdapters::AbstractAdapter类,您将看到一个名为log的方法。在每个查询上调用此方法以记录语句。默认情况下,它使用Rails记录器记录所有语句

Ruby:如何将变量设置为 0,或者如果已经设置,则递增 1

我知道||=运算符,但我认为它不会对我有帮助...尝试创建一个数组来计算对象数组中“类型”的数量。array.eachdo|c|newarray[c.type]=newarray[c.type]?newarray[c.type]+1?0end有没有更优雅的方式来做到这一点? 最佳答案 types=Hash.new(-1)#Itfeelslikethisshouldbe0,buttobe#equivalenttoyourexampleitneedstobe-1array.eachdo|c|types[c.type]+=1end

sql - 在多少种语言中,Null 不等于任何东西,甚至不等于 Null?

在多少种语言中,Null不等于Null? 最佳答案 在SQL(作为一种逻辑语言)中就是这样,因为null表示未知/未定义。但是,在编程语言(例如C++或C#)中,空指针/引用是具有特定含义的特定值——没有任何意义。两个无是等价的,但两个未知数不是等价的。造成混淆的原因是两个概念使用了相同的名称(null)。 关于sql-在多少种语言中,Null不等于任何东西,甚至不等于Null?,我们在StackOverflow上找到一个类似的问题: https://stac