我一直在阅读所有与UTF-8相关的问题和博客文章,并且我在一个test.rb文件中获得了以下示例:
# encoding: UTF-8
File.open("test.txt", "w") do |f|
f.write "test © foo"
end
File.open("test.txt", "r") do |f|
puts f.read
end这个可以完美地工作。它在文件中正确地生成©符号,并将©读回给我并在屏幕上打印出来。
但是,当我在实际项目中使用相同的代码时,我会将以下代码写入文件,而不是©符号:\u00A9
FWIW:在对我的代码运行rspec (v1.2.9)测试时,我得到了这个结果。等级库将生成一个包含©符号的文件,然后重新读入该文件以检查内容。
目前我在Ruby 1.9.2中运行,但我也需要一直支持Ruby 1.8.6。这是一个使用RubyInstaller.org版本的Ruby的Windows环境。
发布于 2012-05-11 18:09:54
如果我执行你的代码,我会得到一个关于特殊字符的错误。你能试试这段代码吗?
# encoding: UTF-8
File.open("test.txt", "w:UTF-8") do |f|
f.write "test \u00A9 foo"
end
#Encoding.filesystem = "UTF-8"
p Encoding.find("filesystem")
File.open("test.txt", "r:UTF-8") do |f|
puts f.read
end 在我的windows box上,我得到了
#<Encoding:Windows-1252>
test © foo我不知道为什么它会在那里..
发布于 2014-01-24 17:39:17
用更少的代码读取文件:
# encoding: UTF-8
file_content = File.open("test.txt", "r:UTF-8", &:read)发布于 2011-03-02 15:46:51
您的应用程序在哪种操作系统上运行?文件的默认编码可能是ASCII。如果您将w:utf-8和r:utf-8添加到打开参数中,会有帮助吗?
https://stackoverflow.com/questions/5163339
复制相似问题