草庐IT

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 - 如何解析 URL 并提取所需的子字符串

假设我有这样一个字符串:"http://something.example.com/directory/"我想做的是解析这个字符串,并从字符串中提取"something"。第一步,显然要检查以确保字符串包含"http://"-否则,它应该忽略该字符串。但是,我如何才能提取该字符串中的"something"?假设这将要评估的所有字符串都具有相似的结构(即我正在尝试提取URL的子域-如果正在检查的字符串确实是一个有效的URL-其中有效以"http://").谢谢。附言我知道如何检查第一部分,即我可以简单地在"http://"处拆分字符串,但这并不能解决全部问题,因为这会产生"http://

ruby - 学习树顶

我正在尝试自学Ruby的Treetop语法生成器。我发现,不仅“最佳”文档的文档少得可怜,而且它似乎也不像我希望的那样直观地工作。在高层次上,我真的很喜欢比现场文档或视频更好的教程,如果有的话。在较低的层次上,这是一个我根本无法使用的语法:grammarSimpleTestrulenum(float/integer)endrulefloat((('+'/'-')?plain_digits'.'plain_digits)/(('+'/'-')?plain_digits('E'/'e')plain_digits)/(('+'/'-')?plain_digits'.')/(('+'/'-')

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 - 你如何让 DateTime.parse 返回你所在时区的时间?

我需要这个require'date'DateTime.parse"Mon,Dec276:30pm"返回EDT时区下午6:30的DateTime,但返回UTC时间。如何获取EST日期时间或将UTC日期时间转换为具有下午6:30值的EDT日期时间? 最佳答案 好的,我要回答我自己的问题require'time'ENV["TZ"]="US/Eastern"Time.parse("Mon,Dec276:30pm").to_datetime=># 关于ruby-你如何让DateTime.parse

Ruby:将嵌套数组的字符串表示形式解析为数组?

假设我有字符串"[1,2,[3,4,[5,6]],7]"我如何将其解析为数组[1,2,[3,4,[5,6]],7]?嵌套结构和模式在我的用例中是完全任意的。我目前的临时解决方案包括在每个句点后添加一个空格并使用YAML.load,但如果可能的话,我想要一个更简洁的解决方案。(如果可能,不需要外部库的一个) 最佳答案 使用JSON正确解析了该特定示例:s="[1,2,[3,4,[5,6]],7]"#=>"[1,2,[3,4,[5,6]],7]"require'json'#=>trueJSON.parses#=>[1,2,[3,4,[5

ruby - 如何在 Nokogiri/Ruby 解析期间检查页面上是否存在元素?

在使用Nokogiri(Rubygem)解析HTML页面期间,我如何检查页面上是否存在元素(在本例中为div)?在我的测试页面上,它确实存在,因此pp会产生预期的Nokogiri输出。但是if语句不起作用,==true似乎是错误的方法。有什么改进建议吗?干杯,克里斯pppage.at('.//div[@class="errorMsg"]')ifpage.at('.//div[@class="errorMsg"]')==truethenputs"Errormessagefoundonpage"end 最佳答案 与true比较不是正确的

ruby-on-rails - 如何在 Rails 测试中轻松解析带参数的 URL?

我有一些代码将return_toURL嵌入到我要测试的重定向(如OpenID)中:deftest_uses_referrer_for_return_toexpected_return_to='http://test.com/foo'@request.env['HTTP_REFERER']=expected_return_toget:fazbot#@response.redirected_tolookslikehttp://service.com?...&return_to=[URI-encodedversionofURLabove]&...encoded_return_to=(some

ruby - 使 Date#parse 采用美国格式而不是欧盟格式

在1.9.2p0中,Date#parse采用UE格式。如果您不相信我,请查看format.rb,第1042行。无论如何,我怎样才能让它采用美国格式,以便:>Date.parse("10/4/2010")=>Mon,04Oct2010而不是4月10日。我已经试过了:classDatedef_parse_eu(str,e)_parse_us(str,e)endend但运气不好。还有其他想法吗? 最佳答案 Date.strptime是你想要的但不幸的是它看起来不像文档有日期格式字符串。我得到以下基于格式字符串的谷歌搜索的工作:1.9.2>

ruby - Ruby 中优雅的日期解析

我在Controller操作中有两个日期参数,如果它们为零或解析失败,我想回退到默认值。不幸的是,如果解析失败,DateTime.strptime似乎会抛出异常,这迫使我写下这个怪物:starting=ifparams[:starting].present?beginDateTime.strptime(params[:starting],"%Y-%m-%d")rescue@meeting_range.firstendelse@meeting_range.firstend感觉不好的人。有没有什么方法可以使用不需要begin...rescueblock的Rubystdlib来解析日期?Ch