草庐IT

c++ - boost 序列化和 double

全部标签

ruby - UTF-8 中的无效字节序列 (ArgumentError)

我正在尝试运行Ruby脚本,但总是在这一行出现错误:file_content.gsub(/dr/i,'med')我试图用“med”替换“dr”的地方。错误是:program.rb:4:in`gsub':invalidbytesequenceinUTF-8(ArgumentError)这是为什么,我该如何解决这个问题?我正在使用Ruby2.2.1p85的MACOSXYosemite机器上工作。 最佳答案 可能你的字符串不是UTF-8格式,所以使用if!file_content.valid_encoding?s=file_content

ruby-on-rails - 如何全局忽略 UTF-8 字符串中的无效字节序列?

我有一个Rails应用程序从Rails版本1开始迁移,我想忽略它上面的所有无效字节序列,以保持向后兼容性。我不知道输入编码。例子:>"-Men\xFC-".split("n")ArgumentError:invalidbytesequenceinUTF-8from(irb):4:in`split'from(irb):4from/home/fotanus/.rvm/rubies/ruby-2.0.0-rc2/bin/irb:16:in`'我可以在一行中解决这个问题,例如:>"-Men\xFC-".unpack("C*").pack("U*").split("n")=>["-Me","ü-

ruby-on-rails - Ruby on Rails 高级 JSON 序列化

我希望在我的Rails应用程序中通过JSON呈现所有文章的索引以及完整的文章,但我在弄清楚如何去做时遇到了一些麻烦。现在这是我的Controller:ifparams[:id]@article=Article.find(params[:id])else@article=Article.published.not_draft.by_recent.firstendrespond_todo|format|format.js{render:json=>@article.to_json(:except=>[:created_at,:updated_at,:draft,:id,:publish],

ruby - 为什么 double splat 仅适用于符号键?

双splat运算符**似乎只适用于键为符号的哈希。例如,当键是字符串时,它将不起作用。两种方式都是如此。用于build:deffoo**;endfoo(:a=>3)#=>nilfoo("a"=>3)#=>ArgumentError:wrongnumberofarguments(1for0)和破坏:defbar*;endbar(**{:a=>3})#=>nilbar(**{"a"=>3})#=>TypeError:wrongargumenttypeString(expectedSymbol)为什么仅限于符号键?这可能与命名关键字符号a:3与hashwithsymbolkeys的语法糖重合

ruby-on-rails - 哪里用 `FactoryGirl.build_stubbed` 哪里用RSpec的 `mock`/`double`

我很好奇人们在编写RSpec规范时倾向于在哪里使用FactoryGirl.build_stubbed以及他们在哪里使用double。也就是说,是否有最佳实践,例如“仅在相应的模型规范中使用FactoryGirl方法?”当您发现自己在spec/models/bar_spec.rb中使用FactoryGirl.create(:foo)时,是否有代码味道?如果您在spec/models/bar_spec.rb中使用FactoryGirl.build_stubbed(:foo),代码味道会不会变小?如果您在foos_controller_spec.rb中使用FactoryGirl.create

UTF-8 中的 Ruby 无效字节序列

我有以下代码,它给了我一个指向扫描方法的无效字节序列错误initialize.有想法该怎么解决这个吗?对于它的值(value),错误不会在(.*)时发生。在h1标签和结束>之间不存在。#!/usr/bin/envrubyclassNewsParserdefinitializeDir.glob("./**/index.htm")do|file|@file=IO.readfileparsed=@file.scan(/(.*?)(.*)/im)self.write(parsed)endenddefwriteoutput@contents=outputopen('output.txt','a'

ruby-on-rails - rake 任务因 US-ASCII 中的无效字节序列而失败

升级到ruby​​1.9.3后,我的一个应用程序运行良好,但当我尝试使用capistrano进行部署时,我尝试转换的第二个应用程序在“assets:precompile”阶段失败。这是堆栈跟踪:rakeaborted!rakeaborted!invalidbytesequenceinUS-ASCII/Users/george/.rvm/gems/ruby-1.9.3-p392@global/gems/rake-10.0.4/lib/rake/trace_output.rb:16:in`blockintrace_on'/Users/george/.rvm/gems/ruby-1.9.3-

ruby - ruby 1.9 中有没有办法从字符串中删除无效的字节序列?

假设你有一个像"€foo\xA0"这样的字符串,编码为UTF-8,有没有办法从这个字符串中删除无效的字节序列?(所以你得到"€foo")在ruby​​-1.8中,您可以使用Iconv.iconv('UTF-8//IGNORE','UTF-8',"€foo\xA0")但现在已弃用。"€foo\xA0".encode('UTF-8')不执行任何操作,因为它已经是UTF-8。我试过:"€foo\xA0".force_encoding('BINARY').encode('UTF-8',:undef=>:replace,:replace=>'')产生“foo”但这也丢失了有效的多字节字符€

ruby-on-rails - 如何重置 factory_girl 序列?

前提是我有项目工厂Factory.define:projectdo|p|p.sequence(:title){|n|"project#{n}title"}p.sequence(:subtitle){|n|"project#{n}subtitle"}p.sequence(:image){|n|"../images/content/projects/#{n}.jpg"}p.sequence(:date){|n|n.weeks.ago.to_date}end我正在创建项目实例Factory.build:projectFactory.build:project此时,下次我执行Factory.b

ruby-on-rails - 在 postgresql 应用程序的 rails 中运行迁移后的序列通知

当我在postgresql上的Rails应用程序中运行我的迁移时,我得到了以下通知NOTICE:CREATETABLEwillcreateimplicitsequence"notification_settings_id_seq"forserialcolumn"notification_settings.id"NOTICE:CREATETABLE/PRIMARYKEYwillcreateimplicitindex"notification_settings_pkey"fortable"notification_settings"我的迁移文件包含088_create_notificati