Parsing HTML using regexes and arrays

I have a nice little regex to pull the information rich guts from a

%r{</thead.?>(.?)}m =~html

$1 now contains all the rows of the table as one long string.

I’d like to turn that into an array of rows, but I am not exactly sure

Additionally, I’d like to process the rows so that i can get data from
between the nth


Any help?

On Fri, Nov 7, 2008 at 3:08 PM, soldier.coder
[email protected] wrote:

between the nth


Any help?

If you have a string with a repeating pattern that you want an array
of, String#scan is your man.

irb(main):001:0> html = “

=> “foobar”
irb(main):002:0> a = html.scan(/(.+?)</td>/)
=> [[“foo”], [“bar”]]

Hmmm, that’s sort of ugly.

irb(main):003:0> a = html.scan(/

=> [“foo”, “bar”]

Much better.

Ad hoc regexes are fine for quick-n-dirty scripting. But if you’re
serious about parsing HTML you might want to look into Hpricot or

-Michael L.

This forum is not affiliated to the Ruby language, Ruby on Rails framework, nor any Ruby applications discussed here.

| Privacy Policy | Terms of Service | Remote Ruby Jobs