jjzjj

读取时出现 Ruby CSV UTF8 编码错误

这是我在做的:csv=CSV.open(file_name,"r")我用它来测试:line=csv.shiftwhilenotline.nil?putslineline=csv.shiftend我遇到了这个:ArgumentError:invalidbytesequenceinUTF-8我读了answerhere这就是我尝试过的csv=CSV.open(file_name,"r",encoding:"windows-1251:utf-8")我遇到了以下错误:Encoding::UndefinedConversionError:"\x98"toUTF-8inconversionfromW

Ruby 1.9.3 - CSV.table 如何知道 CSV 文件中是否没有 header ?

我一直在用CSV.table做一些测试。我有两个几乎相同的小CSV文件,但其中一个缺少标题行。当我对带有标题行的CSV文件运行CSV.table时,一切都按预期进行。当我针对没有标题行的CSV文件运行它时,我得到:NoMethodError:undefinedmethod`encode'fornil:NilClass我用不同类型的数据、不同类型的header尝试了这个,并得到了相同的结果。我很好奇CSV.table的魔力。如果我使用CSV.parse并将标题设置为true,那么无论如何它总是使第一行成为标题。所以,我一直在使用CSV.table来检查导入的CSV文件是否有标题行,但我对

ruby-on-rails - 如何使方法应用于 ActiveRecord 对象的集合

目前,如果我想将一个方法应用于一组ActiveRecord对象,我必须像这样构建调用:messages=Message.find(:all)csv=Message.to_csv(messages)如何定义方法,使其结构如此?messages=Message.find(:all)csv=messages.to_csv这是当前模型代码:require'fastercsv'classMessage 最佳答案 以下将在消息数组中包含的所有实例上调用to_csv。messages=Message.find(:all)csv=messages.

ruby - 如何将 CSV 转换为 Excel?

Ruby中是否有任何插件可以将CSV文件转换为Excel。我几乎没用谷歌搜索,但我发现的只是将Excel文件转换为CSV。我知道一些我可以稍微调整并用于将Excel转换为CSV的gem,但我需要知道以前是否有人这样做过。 最佳答案 根据thispost,spreadsheetgem是一种可能性。看起来这是一个非常受欢迎的gem。看看这个。例子:book=Spreadsheet::Workbook.newsheet1=book.create_worksheetheader_format=Spreadsheet::Format.new(

ruby-on-rails - 事件管理员 CSV 导出自定义查询范围

我正在使用活跃的管理员导出CSV选项。它返回与特定表相关的所有值。我只想要特定月份的报告。有人能帮忙吗? 最佳答案 您可以编写自己的csv导出器collection_action:download_report,:method=>:getdousers=User.where('created_at>=?',Date.today-1.month)csv=CSV.generate(encoding:'Windows-1251')do|csv|#addheaderscsv:download_report))endindex:downloa

ruby - Ruby 中的通用换行符支持,包括\r (CR) 行尾

在Rails应用程序中,我正在接受和解析CSV文件,这些文件可能使用以下三种可能的行终止字符中的任何一种进行格式化:\n(LF)、\r\n(CR+LF),或\r(CR)。Ruby的File和CSV库似乎可以很好地处理前两种情况,但最后一种情况(“Macclassic”\r行结尾)不作为换行符处理。能够接受这种格式以及其他格式很重要,因为MicrosoftExcelforMac(在OSX上运行)似乎在导出为“逗号分隔值”时使用它(尽管导出为“Windows逗号分隔”更容易-处理\r\n).Python具有“通用换行支持”,可以毫无问题地处理这三种格式中的任何一种。Ruby中是否有类似的东

Ruby 1.9.2 导出 CSV 字符串而不生成文件

我只是无法在“写作”下获得“到字符串”示例exampleinthedocumentation完全可以工作。ruby-v返回:ruby1.9.2p290(2011-07-09修订版32553)[x86_64-darwin10.8.0]我无法使用的文档示例在这里:csv_string=CSV.generatedo|csv|csv我得到的错误是:wrongnumberofarguments(0for1)看来我在文档中遗漏了一个参数here它指出:ThismethodwrapsaStringyouprovide,oranemptydefaultString但是当我传入一个空字符串时,会出现以下

ruby - 在 Ruby CSV 中,如何将空白 , 而不是 ,""写入文件?

Ruby1.9版本的csvheader%w[firstsecondthird]data=["columnone",,"columnthree"]CSV.open("myfile.csv","w")do|csv|csv在这个简单的示例中,数据数组中的空中间,,会导致错误,但如果使用空引号,"",则不会出现错误,并且会创建CSV文件。但是我想让CSV文件没有空的引号段。具体来说,如何生成不带引号的CSV文件的空白部分?数据可以是空变量,但它仍然应该写逗号。 最佳答案 使用data=["columnone",nil,"columnthre

Ruby:如何生成具有 Excel 友好编码的 CSV 文件

我正在生成CSV文件,这些文件生成后需要在Excel中打开和查看。Excel似乎需要与UTF-8不同的编码。这是我的配置和生成代码:csv_config={col_sep:";",row_sep:"\n",encoding:Encoding::UTF_8}csv_string=CSV.generate(csv_config)do|csv|csv在Excel中打开时,特殊字符显示不正确:TextaTextbTextæTextøTextÃ¥知道如何确保正确编码吗? 最佳答案 如果Excel具有BOM,则它可以理解UTF-8CSV。可

ruby-on-rails - 将 CSV 流从 Ruby 上传到 S3

我正在处理潜在的巨大CSV文件,我想从我的Rails应用程序导出这些文件,并且由于它在Heroku上运行,我的想法是在生成这些CSV文件时将它们直接流式传输到S3。现在,我遇到了一个问题,因为Aws::S3需要一个文件才能执行上传,而在我的Rails应用程序中我想做类似的事情:S3.bucket('my-bucket').object('my-csv')我怎样才能做到这一点? 最佳答案 您可以使用s3分段上传,允许通过将大对象拆分为多个block来上传。https://docs.aws.amazon.com/AmazonS3/lat