草庐IT

ruby - 从字符串中删除双引号

我正在尝试从MySQL数据库中获取数据并使用Ruby将其重新格式化为纯文本文件。我的一些MySQL数据包含双引号,如下所示:Matthew"Matt"Perry我需要删除这些引号并将它们替换为其他内容,|例如。我在stackoverflow上发现了另一篇关于删除引号的帖子,建议如下:s.scan(/'(.+?)'|"(.+?)"|([^]+)/).flatten.compact但这会返回完整的字符串(带双引号)。我怎样才能得到Matthew|Matt|Perry代替? 最佳答案 如果您不想修改,可以这样做:new_s=s.gsub/

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 - 在 Ruby 中展平字符串数组

将字符串数组转换为字符串的最佳惯用(最干净)方法是什么,同时保留每个元素的引号。换句话说,从这个:a=["file1.txt","file2.txt","file3.txt"]我需要得到这个"'file1.txt''file2.txt''file3.txt'"这里单引号和双引号可以互换。我知道的最好方法是使用映射和注入(inject)/减少。例如:a.map{|dir|"'"+dir+"'"}.join('')eg2:a.reduce("'"){|acc,dir|acc+=dir+"'"}可以通过避免创建临时字符串(+运算符)来提高性能。但这不是我的主要问题。有没有更简洁的方法来达到相

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-on-rails - 何时在 Rails 应用程序中使用单引号与双引号

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:WhichstyleofRubystringquotingdoyoufavour?关于何时在ruby​​中使用单引号或双引号,尤其是Rails应用程序,是否有好的经验法则?一个不比另一个使用更多的内存吗?Rails社区是否有任何约定?

ruby - 如何强制 Ruby 的 CSV 输出中的一个字段用双引号引起来?

我正在使用Ruby的内置CSV生成一些CSV输出。一切正常,但客户希望输出中的名称字段包含双引号,以便输出看起来像输入文件。例如,输入看起来像这样:1,1.1.1.1,"FirstnameLastname",more,fields2,2.2.2.2,"FirstnameLastname,Jr.",more,fieldsCSV的正确输出如下所示:1,1.1.1.1,FirstnameLastname,more,fields2,2.2.2.2,"FirstnameLastname,Jr.",more,fields我知道CSV的做法是正确的,因为它没有双引号第三个字段,只是因为它嵌入了空格,

ruby - 导入 CSV 引用错误让我抓狂

尝试在ruby​​-1.9.2中导入CSV文件的过程令人难以置信。我要解析的文件有:列中的逗号列内引用使用“@”作为:col_sepcsv.txt(代表输入,真正的是101k行):㔾@㔾@jié@"seal"radicalinChinesecharacters,(Kangxiradical26)我的代码:require'csv'CSV.foreach("/Users/adam/Desktop/csvtest.txt",{:col_sep=>"@"})do|row|putsrow.to_send我想要的输出:["㔾","㔾","jié","\"seal\"radicalinChinese

ruby - 在反引号运算符中替换变量的值

如何替换反引号运算符中的变量值?script_dir=File.expand_pathFile.dirname(__FILE__)p`ruby-ep"$script_dir"`#thisdoesnotwork 最佳答案 在Ruby中,与Perl不同,美元符号表示全局变量,而不是在字符串中扩展的普通常规变量。在字符串中,您需要使用#{}结构:p`ruby-e"p#{script_dir}"`一个例子:irb(main):011:0>str='\'howdy\''=>"'howdy'"irb(main):012:0>`ruby-e"p#

Ruby gsub 不会转义单引号

我不明白这是怎么回事。我应该如何输入gsub以获取字符串“Yaho\'o”?>>"Yaho'o".gsub("Y","\\Y")=>"\\Yaho'o">>"Yaho'o".gsub("'","\\'")=>"Yahooo" 最佳答案 \'表示$'是匹配后的所有内容。再次转义\就可以了"Yaho'o".gsub("'","\\\\'") 关于Rubygsub不会转义单引号,我们在StackOverflow上找到一个类似的问题: https://stackove