jjzjj

Encoding

全部标签

Ruby 不兼容的字符编码

我目前正在尝试编写一个脚本来遍历输入文件并检查网站上的数据。如果它找到新数据,它会打印到它通过的终端,如果没有,它会告诉我它失败了。反之亦然删除的数据。它工作正常,直到我收到的输入文件包含“™”字符。然后当ruby​​到达该行时,它会吐出一个错误:PDAPWeb.rb:73:in`include?':incompatiblecharacterencodings:UTF-8andIBM437(Encoding::CompatibilityError)违规行是一个简单的检查,以查看该文本是否存在于页面上。ifbrowser.text.include?(program_name)其中prog

ruby 从任何编码到 ascii

我必须主要处理英文字母和所有标点符号,我不必担心欧洲口音。所以我唯一担心的是,当用户粘贴他从网上复制的内容时,例如,当我在控制台(在Win7上)中执行一个撇号时,它会输出"ItΓÇÖs"#它实际上在哪里"It's"所以我的主要问题是,是否有一种我可以在Ruby中使用的完全转换方法,它可以正确地替换所有,.;?!"'~`_-与ASCII计数器部分?我真的对编码知之甚少,如果您认为这是错误的问题(很可能是这种情况),请就我应该寻找的内容提出建议。谢谢 最佳答案 我在出版业工作,我们经常处理这个问题。我们在stringex上取得了成功ht

ruby - 如何在 Ruby 中列出有效的 Iconv 编码?

如何在windows7下获取Ruby1.9.1中的有效Iconv编码列表? 最佳答案 也许这会有所帮助:putsEncoding.listputsEncoding.aliases它返回一个加载的编码列表,以及一个编码别名的散列:ASCII-8BITUTF-8US-ASCIIBig5CP949Emacs-MuleEUC-JPEUC-KREUC-TW...{"BINARY"=>"ASCII-8BIT","CP437"=>"IBM437","CP737"=>"IBM737","CP775"=>"IBM775","IBM850"=>"CP8

Ruby 1.9 和 Sass 编码问题。 (从 ASCII-8BIT 到 UTF-8)

我最近升级到Ruby1.9,我不能再用Sass编译任何东西。我见过说明我是否放置的解决方案@charset"utf-8";在我的.sccs文件的顶部,它会修复它。但是我仍然遇到错误。这是完整的回溯我也试过从我的CSS文件中删除任何非ascii字符,创建一个新字符等。它就是无法编译。有什么建议吗?回溯:Sassiswatchingforchanges.PressCtrl-Ctostop./home/webdev/.gem/repository/gems/sass-3.1.1/lib/sass/util.rb:496:in`encode':transcodingnotsupported(f

ruby-on-rails - 直接显示使用 chunkypng 创建的图像(不保存)

所以我使用chunky_png创建了一个PNG图像.我不想保存这张图片,因为它只对这个请求有用,所以我试图将这张图片保存为实例变量并将其显示在我的View中。问题是,在我看来,这会导致UTF-8中的无效字节序列错误。我做了什么:#controller@img=source_img.resize(200,200).to_string#view"/>使用raise@img.to_yaml调试@img变量输出正确的字符串,f.e.:---!binary|-iVBORw0KGgoAAAANSUhEUgAAAMgAAADIAQAAAACFI5MzAAACP0lEQVR4nO1YQY6jQAy0A

ruby-on-rails - Rails 在我的纯文本电子邮件中转义 HTML

我正在使用rails3.2.5ActionMailer发送纯文本邮件。鉴于我有这样的邮件View:message_from_user.text.erb:Hi,Yougotthefollowingmessagefrom:当@message是"quotes&ersands",那么纯文本邮件包含"quotes&ampersands".所以看起来rails只是将其视为HTMLView并转义任何html以防止跨站点脚本。然而,这是一封纯文本邮件。分机号是.text.erb和ActionMailer检测到这一点并将MIME设置为text/plain.所以我从不想转

ruby 1.9 + sinatra 不兼容的字符编码 : ASCII-8BIT and UTF-8

我正在尝试将sinatra应用程序迁移到ruby​​1.9我正在使用sinatra1.0、rack1.2.0和erb模板当我启动sinatra时它可以工作,但是当我从浏览器请求网页时出现此错误:Encoding::CompatibilityErrorat/incompatiblecharacterencodings:ASCII-8BITandUTF-8所有.rb文件都有这个标题:#!/usr/bin/envruby#encoding:utf-8我认为问题出在erb文件中,即使它显示它是UTF-8编码[user@localhostviews]$filehome.erbhome.erb:U

ruby - 在我的 ramaze 应用程序上显示 £ 符号时,我收到 "incompatible character encodings: CP850 and UTF-8"

在我的ramaze应用程序上显示£符号时,我收到“不兼容的字符编码:CP850和UTF-8”。我怎样才能摆脱这个错误?我的head标签中有UTF-8元标签。当我用键盘输入£符号时会发生这种情况。看。我已将以下代码放入我的ruby​​文件中,但没有解决问题。#encoding:UTF-8Encoding.default_external='utf-8'Encoding.default_internal=Encoding::UTF_8 最佳答案 尝试强制编码以查看是否可以解决问题:your_string.force_encoding(:

ruby - 如何删除 ruby 中的不可打印/不可见字符?

有时我在字符串中间有邪恶的不可打印字符。这些字符串是用户输入的,所以我必须让我的程序很好地接收它,而不是试图改变问题的根源。例如,他们可以有zerowidthno-breakspace在字符串的中间。例如,在解析.po文件时,一个有问题的部分是文件中间的字符串"heisamanofgod"。虽然一切看起来都是正确的,但使用irb检查它会显示:"heisamanofgod".codepoints=>[104,101,32,105,115,32,97,32,65279,109,97,110,32,111,102,32,103,111,100]我相信我知道什么是BOM,而且我什至能很好地处理

Ruby String.encode 仍然给出 "invalid byte sequence in UTF-8"

在IRB中,我正在尝试以下操作:1.9.3p194:001>foo="\xBF".encode("utf-8",:invalid=>:replace,:undef=>:replace)=>"\xBF"1.9.3p194:002>foo.match/foo/ArgumentError:invalidbytesequenceinUTF-8from(irb):2:in`match'知道出了什么问题吗? 最佳答案 我猜"\xBF"已经认为它是用UTF-8编码的,所以当你调用encode时,它认为你正在尝试编码一个UTF-8中的UTF-8字符