繁体   English   中英

在Ruby中解析字符串(Regexp?)

[英]Parsing a String in Ruby (Regexp?)

我有一个弦

Purchases 10384839,Purchases 10293900,Purchases 20101024

谁能帮我解析这个问题? 我尝试使用StringScanner,但是我对正则表达式有点陌生(不是很多练习)。

如果我能把它分成

myarray[0] = {type => "Purchases", id="10384839"}
myarray[1] = {type => "Purchases", id="10293900"}
myarray[2] = {type => "Purchases", id="20101024"}

太棒了!

string = "Purchases 10384839,Purchases 10293900,Purchases 20101024"
string.scan(/(\w+)\s+(\d+)/).collect { |type, id| { :type => type, :id => id }}

您可以使用正则表达式来做到这一点,也可以只在Ruby中来做到这一点:

myarray = str.split(",").map { |el| 
    type, id = el.split(" ")
    {:type => type, :id => id } 
}

现在,您可以像“ myarray [0] [:type]”那样解决它。

正则表达式不是必需的,也可能不是最清晰的方法。 在这种情况下,您需要的方法是split 这样的事情会起作用

raw_string = "Purchases 10384839,Purchases 10293900,Purchases 20101024"
myarray = raw_string.split(',').collect do |item|
  type, id = item.split(' ', 2)
  { :type => type, :id => id }
end

可在以下位置找到split和collect方法的文档:

可枚举
String.split

这是一个irb会话:

dru$ irb
irb(main):001:0> x = "Purchases 10384839,Purchases 10293900,Purchases 20101024"
=> "Purchases 10384839,Purchases 10293900,Purchases 20101024"
irb(main):002:0> items = x.split ','
=> ["Purchases 10384839", "Purchases 10293900", "Purchases 20101024"]
irb(main):006:0> items.map { |item| parts = item.split ' '; { :type => parts[0], :id => parts[1] } }
=> [{:type=>"Purchases", :id=>"10384839"}, {:type=>"Purchases", :id=>"10293900"}, {:type=>"Purchases", :id=>"20101024"}]
irb(main):007:0> 

从本质上讲,我会先将','分开。 然后,我将每个项目按空间拆分,并创建带有各部分的哈希对象。 无需正则表达式。

   s = 'Purchases 10384839,Purchases 10293900,Purchases 20101024'
   myarray = s.split(',').map{|item| 
       item = item.split(' ')
       {:type => item[0], :id => item[1]} 
   }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM