草庐IT

java - 用于 UTF-8 或 ISO-8859-1 编码 XML 的动态 SAX 解析器

全部标签

ruby-on-rails - 在 RoR 中对 UTF-8 字符串进行排序

我正试图找出一种在RubyonRails中对UTF-8字符串进行排序的“正确”方法。在我的应用程序中,我有一个填充了国家/地区的选择框。由于我的应用程序已本地化,每个现有的语言环境都有一个countries.yml文件,该文件将国家的ID与该国家/地区的本地化名称相关联。我无法在yml文件中手动对字符串进行排序,因为我需要ID在所有语言环境中保持一致。我所做的是创建一个使用unidecode的ascii_name方法gem将重音字符和非拉丁字符转换为对应的ascii字符(例如,“Afeganistão”将变为“Afeganistao”),然后对其进行排序:require'unideco

ruby-on-rails - 为什么我会收到从 ASCII-8BIT 到 UTF-8 的字符串编码问题 "\xE2"?

我正在尝试从电子邮件下载PDF并将内容写入文件。出于某种原因,我收到此错误:AnEncoding::UndefinedConversionErroroccurredinattachments#inbound:"\xE2"fromASCII-8BITtoUTF-8app/controllers/api/attachments_controller.rb:70:in`write'这是我的代码:definboundifRails.env.production?orRails.env.staging?email=Postmark::Mitt.new(request.body.read)else

ruby - 是否存在用于匹配哈希的 RSpec2 匹配器?

future读者请注意:认为RSpec不认为您的哈希值相等?一个可能是OrderedHash,但从常规的RSpec输出中您无法分辨。这就是引发这篇文章的问题。原始问题:假设我有一个规范,我想在其中测试某个方法是否生成了适当的哈希值。it'shouldgeneratetheHashcorrectly'doexpected={:foo=>1,'baz'=>2}subject.some_method_that_should_generate_the_hash.should==expectedend这经常会失败,因为具有相同键值对的不同哈希可能会以不同的顺序返回它们的对。结果如下:Failur

ruby-on-rails - 将 Ruby Gems 类比为 Java JAR 是否有效?

我相信我已经非常清楚和简洁地提出了这个问题。我为什么要问?我要向学生解释RubyonRails框架,这需要我对Java世界做一些类比(因为该类(class)非常以Java为中心)。我没有RubyonRails的实践经验,但我觉得Gem/Jar类比是有效的。谁能进一步阐明这个问题? 最佳答案 作为一个简短的回答,我会说:是的,它是有效的。作为一个长答案,我会说:是的,它是有效的,但您可能还想描述一些重要的区别。jar有一些与gem截然不同的品质。JAR是打包的可执行库,您通常必须在调用时在Java程序的执行中显式声明依赖项(通过在调用

ruby - 在 Heroku 中将 UTF-8 设置为默认字符串编码

我需要在Heroku中将默认的ruby​​字符串编码更改为UTF-8。由于某种原因,它是US-ASCII。$herokuconsoleRubyconsoleformyapp.heroku.com>>"a".encoding=>#但是,如果我在本地运行irb,我会得到不同的结果:$irbruby-1.9.2-p136:001>"a".encoding=>#两者都在ruby​​1.9.2上运行。我也试过设置这个,但没用:Encoding.default_internal=Encoding.default_external="UTF-8"想法?谢谢,菲利普 最佳答

ruby - Heroku gem 不适用于 RVM

我正在学习http://railstutorial.org/chapters/beginning#sec:1.4.1上的RubyonRails教程,在我尝试让我的应用程序在Heroku上运行之前,一切都很顺利。我安装了heroku,运行良好,但现在当我运行herokukeys:add或任何其他heroku命令时,出现以下错误:/home/sirswap/.rvm/gems/ruby-1.9.2-p0@rails3tutorial/gems/rest-client-1.4.2/lib/restclient.rb:9:in`rescuein':nosuchfiletoload--net/h

ruby - 是否有适用于 ruby​​ 2.0 的 pry 调试设置?

我在OSX上使用ruby​​2.0.0-p195。pry-debugger不工作(step/continue/next都像continue一样工作)。是否有适用于ruby​​2.0的调试gem?更新:pry-debugger和pry-byebug似乎都可以在一个简单的项目中使用ruby​​2.0.0-p195。在测试中使用binding.pry时,我有一些其他冲突导致两者都失败...更新:pry-byebug正在为我使用最新的ruby​​2.0版本2.0.0-p247,以及pry-byebug1.1.1和byebug1.5.0 最佳答案

ruby - 使用 Nokogiri 插入和删除 XML 节点和元素

我想提取XML文件的一部分,并记下我提取了该文件中的某些部分,例如“这里提取了一些东西”。我正尝试用Nokogiri来做这件事,但似乎并没有真正记录如何:删除的所有child更改inner_text那个完整的元素有什么线索吗? 最佳答案 Nokogiri让这一切变得非常简单。使用thisdocument例如,以下代码将找到所有vitamins标签,删除它们的子标签(以及子标签的子标签等),并将它们的内部文本更改为“Childrenremoved”。require'nokogiri'io=File.open('sample.xml',

ruby - 如何在 Ruby 中删除 4 字节的 utf-8 字符?

由于MySQL的utf8不支持4字节字符,我正在寻找一种方法来检测和消除Ruby字符串中的任何4字节utf8字符。我知道我可以更新我的表以使用utf8m4,但由于一些不可能或所需的解决方案的原因。简单地将字符串编码为ASCII会删除这些字符,但也会删除所有其他非ASCII字符,这并不好。 最佳答案 以下似乎适用于Ruby1.9.3:input.each_char.select{|c|c.bytes.count例如:input="hello\xF0\xA9\xB6\x98world"#includesU+29D98input.each

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