草庐IT

csv - 去 panic : extra delimiter at end of line

全部标签

ruby - 使用 FasterCSV gem 克服 CSV 解析的基本问题

我发现了FasterCSV(1.5.0)的CSV解析问题,这似乎是一个真正的错误,但我希望有一个解决方法。基本上,当字段用引号引起来时,在分隔符后添加一个空格(在我的例子中是逗号)会生成MalformedCSVError。这是一个简单的例子:#Noquotesonfields--worksfineFasterCSV.parse_line("one,two,three")=>["one","two","three"]#Quotesaroundfieldswithnospacesafterseparators--worksfineFasterCSV.parse_line("\"one\",

ruby-on-rails - ruby 中 CSV.open( ) 的第二个参数/参数是什么?

我想我在这里遗漏了一些非常明显的东西,但是每个人为CSV.open方法输入的第二个参数是什么,在本例中是“wb”,我看到这里放了其他字母,但没有人真正解释它的作用。它有什么作用?CSV.open("path/to/file.csv","wb")do|csv|csvruby文档似乎没有给出任何解释。http://www.ruby-doc.org/stdlib-2.0/libdoc/csv/rdoc/CSV.html谢谢! 最佳答案 来自IOOpenMode文档:"r"只读,从文件开头开始(默认模式)。"r+"读写,从文件开头开始。"w

ruby - 如何在 ruby​​ 中读取没有 quote_char 的 CSV?

我有一个没有引号字符的TSV文件。每当数据中出现\t时,它总是分隔列,而不是列值的一部分。每当"出现时,它始终是列值的一部分,并且永远不会包含列值。我想用Ruby阅读这个CSV,但它给了我/Users/.rvm/rubies/ruby-1.9.3-p545/lib/ruby/1.9.1/csv.rb:1925:in`block(2levels)inshift':Illegalquotinginline9506.(CSV::MalformedCSVError)我的代码是:CSV.foreach(input_file,{:col_sep=>"\t",:headers=>true})do|r

Ruby CSV 解析带有转义引号的字符串

我的CSV文件中有一行包含一些转义引号:173,"Yukihiro\"TheRubyGuy\"Matsumoto","Japan"当我尝试使用RubyCSV解析器解析它时:require'csv'CSV.foreach('my.csv',headers:true,header_converters::symbol)do|row|putsrowend我收到这个错误:.../1.9.3-p327/lib/ruby/1.9.1/csv.rb:1914:in`block(2levels)inshift':Missingorstrayquoteinline122(CSV::MalformedCS

ruby-on-rails - 在 Ruby 中,如何从 CSV 文件中按列读取数据?

我知道它是如何逐行完成的CSV.foreach(filename.csv)do|row|puts"#{row}"end但我完全迷失了专栏? 最佳答案 测试.csv:name,surname,no1,no2,no3,dateRaja,Palit,77489,24,84,12/12/2011Mathew,bargur,77559,25,88,01/12/2011harin,Roy,77787,24,80,12/12/2012Soumi,paul,77251,24,88,11/11/2012按列访问:require'csv'csv=CSV

ruby-on-rails - CSV - 未加引号的字段不允许\r 或\n(第 2 行)

尝试解析CSV文件,但仍然收到错误消息Unquotedfieldsdonotallow\ror\n(line2).。我在SOsimilartopic上找到了这里,其中提示执行以下操作:CSV.open('file.csv',:row_sep=>"\r\n")do|csv|但不幸的是他对我不起作用...我无法更改CSV文件,所以我需要在代码中修复它。编辑CSV文件示例:A;B;C1234;...有什么办法吗?非常感谢! 最佳答案 首先,您应该将列分隔符设置为“;”,因为这不是解析CSV文件的常规方式。这对我有用:CSV.open('f

Ruby 1.9.2 - 读取和解析远程 CSV

我正在寻找一种在本地读取和解析远程CSV(托管在特定网站上)的方法。我在Internet上发现了几个使用FasterCSV的有趣示例,在ruby​​1.9.2中已将其合并到CSV中。我发现您可以通过这种方式使用gems'csv'和'open-uri'读取远程CSV:require'csv'require'open-uri'defread(url)open(url)do|f|f.each_linedo|l|CSV.parse(l)do|row|putsrowendendendend但是当我调用这个函数时,我得到一个异常:ERRORIOError:closedstream谁能告诉我为什么?

ruby - 在 ruby​​ 中将 .json 转换为 .csv

我想使用ruby​​将.json文件转换为.csv文件。请帮我做这件事。同时提出实现此目的的任何工具。 最佳答案 尝试这样的事情:require'csv'require'json'csv_string=CSV.generatedo|csv|JSON.parse(File.open("foo.json").read).eachdo|hash|csv 关于ruby-在ruby​​中将.json转换为.csv,我们在StackOverflow上找到一个类似的问题:

ruby - 在 ruby​​ 1.9 和 CSV::Writer 中写入 csv

我有一段代码适用于ruby​​1.87,但不适用于ruby​​1.9。它说CSV::Writer未声明,但它仍然是rdoc的一部分。在fastercsv合并之后,csvapi是否发生了变化?我的代码:require'csv'defself.export_csvfile_name=File.join(RAILS_ROOT,'public','csv',"#{start_date_f}_#{end_date_f}.csv")returnfile_nameifFile.exist?(file_name)@results=find(:all)header_row=[]outfile=File.

ruby-on-rails - 如何在 Ruby on Rails 中下载 CSV 文件?

在我的InvoicesController中我有这个:defindex@invoices=current_user.invoicesrespond_todo|format|format.htmlformat.xlsformat.csv#notworking!endend在我的index.html.erbView中,我有这两个下载链接:"xsl")%>"csv")%>index.xsl.erb和index.csv.erb模板也确实存在。第一个链接有效,即Excel文件下载到用户的计算机上。但是,CSV文件在浏览器中呈现,而不是下载。我必须怎么做才能让用户也能下载CSV文件?感谢您的帮助。