草庐IT

csv_text

全部标签

ruby - 如何将散列保存到 CSV 中

我是ruby​​新手,所以请原谅我的笨拙。我有一个包含两列的CSV。一种用于动物名称,另一种用于动物类型。我有一个散列,所有键都是动物名称,值是动物类型。我想在不使用fasterCSV的情况下将哈希写入CSV。我想到了几个最简单的想法。这是基本布局。require"csv"defwrite_fileh={'dog'=>'canine','cat'=>'feline','donkey'=>'asinine'}CSV.open("data.csv","wb")do|csv|csv当我打开要读取的文件时,我打开了它File.open("blabla.csv",headers:true)是否有

ruby - 将 CSV 文件转换为哈希数组

我有一个csv文件,一些曲棍球统计数据,例如:09.09.2008,1,HCVitkoviceSteel,BKMladaBoleslav,1:0(PP)09.09.2008,1,HCLasselsbergerPlzen,RIOKNAZLIN,6:209.09.2008,1,HCLitvinov,HCSpartaPraha,3:5我想将它们保存在一个哈希数组中。我没有任何header,我想为每个值添加键,例如"time"=>"09.09.2008"等等。每行都应该像arr[i]一样可访问,每个值都应该像arr[i]["time"]一样可访问。我更喜欢CSV类而不是FasterCSV或sp

ruby-on-rails - Ruby/Rails CSV 解析,UTF-8 中的无效字节序列

我正在尝试解析从Excel电子表格生成的CSV文件。这是我的代码require'csv'file=File.open("input_file")csv=CSV.parse(file)但是我得到这个错误ArgumentError:invalidbytesequenceinUTF-8我认为错误是因为Excel将文件编码为ISO8859-1(Latin-1)而不是UTF-8谁能帮我解决这个问题提前致谢。 最佳答案 您需要告诉Ruby该文件在ISO-8859-1中。将您的文件打开行更改为:file=File.open("input_file

ruby-on-rails - 如何将 ActiveRecord 模型数组转换为 CSV?

我有一组ActiveRecord模型,我希望将其转换为CSV。我尝试研究像FasterCSV这样的gem,但它们似乎只适用于字符串和数组,而不适用于ActiveRecord模型。简而言之,我要转换:user1=User.firstuser2=User.lasta=[user1,user2]收件人:id,username,bio,email1,user1,user1bio,user1email1,user2,user2bio,user2email有没有简单的Rails方法可以做到这一点? 最佳答案 下面将所有用户的属性写入一个文件:C

Sublime Text 2 中的 RubyTest

我正在尝试获取RubyTest在SublimeText2中工作。我按照Github自述文件上的说明操作并得到以下错误。有谁知道我该如何解决这个问题?/bin/sh:rspec:commandnotfound 最佳答案 要使其正常工作,您只需更改sb2中RubyTest包中的一项设置。如果您使用的是rvm,则您的rspecgem是通过rvm安装的,并且在/bin/sh中找不到因此您需要为SublimeText2设置RubyTest包以自动检查您的rvm环境变量。要更改的内容:1)在SublimeText2中,转到Preferences

Ruby 的 File.open 给出 "No such file or directory - text.txt (Errno::ENOENT)"错误

我在我的Win7机器上安装了Ruby1.9.2。创建了一个简单的analyzer.rb文件。它有这一行:File.open("text.txt").each{|line|putsline}当我运行代码时,它给我这个错误:analyzer.rb:1:in`initialize':Nosuchfileordirectory-text.txt(Errno::ENOENT)fromanalyzer.rb:1:in`open'fromanalyzer.rb:1:in`'Exitcode:1我不明白。在与analyzer.rb文件相同的目录中有一个text.txt文件。我还尝试输入文件的绝对路径C

Ruby CSV - 获取当前行/行号

我正在尝试弄清楚如何从RubyCSV中获取当前行/行号。这是我的代码:options={:encoding=>'UTF-8',:skip_blanks=>true}CSV.foreach("data.csv",options,)do|row,i|putsiend但这似乎并没有按预期工作。有办法做到这一点吗? 最佳答案 由于当前Rubies中CSV的更改,我们需要进行一些更改。在2.6之前使用Ruby的原始解决方案的答案中进一步查看。以及with_index的使用,无论版本如何,它都可以继续工作。对于2.6+这将有效:require'

ruby - 使用 Ruby CSV 更改导出的 CSV 中的字段分隔符/定界符

是否可以将默认字段分隔符从逗号更改为其他字符,例如用于导出的'|'? 最佳答案 下面是一个使用选项卡的示例。到一个文件:CSV.open("myfile.csv","w",{:col_sep=>"\t"})do|csv|csv到一个字符串:csv_string=CSV.generate(:col_sep=>"\t")do|csv|csv这是关于CSV的当前文档:http://ruby-doc.org/stdlib/libdoc/csv/rdoc/index.html 关于ruby-使用R

ruby-on-rails - 在 Rails 5.1 及更高版本中使用什么代替 `render :text` (和 `render nothing: true` )?

Rails5.1removesawholeloadofpreviouslydeprecatedmethods.其中就有老friendrender:text。当您需要呈现一些文本,但又不想占用View模板的开销时,它非常有用。示例:rendertext:"ok"rendertext:t('business_rules.project_access_denied'),status:401用什么代替? 最佳答案 未弃用的方法是使用render:plainRailsGuideonLayoutsandRendering:2.2.6Render

Ruby 将 CSV 文件读取为 UTF-8 和/或将 ASCII-8Bit 编码转换为 UTF-8

我正在使用ruby1.9.2我正在尝试解析包含一些法语单词(例如spécifié)的CSV文件,并将内容放入MySQL数据库中。当我从CSV文件中读取行时,file_contents=CSV.read("csvfile.csv",col_sep:"$")返回的元素是ASCII-8BIT编码的字符串(spécifié变为sp\xE9cifi\xE9),然后像“spécifié”这样的字符串没有正确保存到我的MySQL数据库中。YehudaKatz表示ASCII-8BIT实际上是“二进制”数据,这意味着CSV不知道如何读取适当的编码。所以,如果我尝试让CSV强制编码如下:file_cont