草庐IT

csv - 用直线引用 csv 输出

全部标签

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 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-on-rails - 有没有办法在 Rails 控制台内的输出上实现类似 grep 的功能

在shell中,我可以做到$catname_of_file_with_a_lot_of_text|grep"WhatIamlookingfor"在Rails控制台中,我能否实现类似的功能,比如当我运行一个命令并且输出很大时,尤其是数据库查询。我知道将其输出为YAML,但这不是我要找的。谢谢。 最佳答案 是的,你可以。该方法称为gr...等待它...ep。Ruby的grep适用于String、Array和许多其他内置对象。例如,要获取一个数字的所有to_xxx方法,只需执行以下操作:1.methods.grep(/to_/)

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 - yield 和违约情况 ||不输出默认情况

我有一个简单的yield用例,由于某些未知原因,默认情况从未显示:在我的super_admin布局中我有:我的ControllerclassSuperadmin::GolfsController我的秀场观有无sadmin_golfs有:显示了sadmin_golfs。没有:显示空字符串而不是super_admin_main任何人都可以重现相同的行为吗? 最佳答案 尝试Object#presence相当于object.present??object:nil(AS3rc文档),并且本质上允许使用带有标题的传统语法。

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

ruby - Hash#keys 方法的错误输出

在某些情况下Hash#keys在2.4之前的Ruby中不能正常工作演示代码:h={a:1,b:2,c:3}h.eachdo|k,v|h.delete(:a)phph.keysbreakendRuby2.3.8输出:{:b=>2,:c=>3}[:b]Ruby2.5.1输出:{:b=>2,:c=>3}[:b,:c]我同意在迭代时修改散列是不好的。但是我没有看到修改hash和workkeys方法之间的关系。为什么会这样? 最佳答案 有趣的问题。这还不是答案,但对于评论来说太长了,它可以帮助其他人回答问题。哪些ruby受到影响?我创建了一个

ruby-on-rails - 自引用问题 has_many :through associations in Rails

我今天正在阅读有关自引用has_many:through数据情况的文章,因为我正在尝试构建一个使用它们的Rails应用程序。我找到了这个examplesituation在互联网上,我对此有疑问。让我从这个人的博客中发布这个示例代码:create_table:animalsdo|t|t.string:speciesendcreate_table:huntsdo|t|t.integer:predator_idt.integer:prey_idt.integer:capture_percentendclassAnimal'predator_id',:class_name=>'Hunt',:d

ruby - 如何解析 CSV 文件,更新字段,然后保存

我需要读取一个CSV文件,更新一个字段,然后保存更改。除了将我的更改保存到我正在更新的字段外,我一切正常:require'csv'@parsed_file=CSV::Reader.parse(File.open("#{RAILS_ROOT}/doc/some.csv"))@parsed_file.each_with_indexdo|row,x|address=row[5]l=Location.address_find(address)ifl!=nilputs"#{l.name}at#{l.address}"row[14]=l.store_codeputsrow[14]elseputs"