re = /\"\"\"(.*?)\"\"\"|'''(.*?)'''|"(.*?)"|'(.*?)'/
str = '#%%sql
"double quoted string"
q = """
select
name, breed, sum(weight) over (partition by breed order by name) as running_total_weight
from cats
order by breed, name
"""
\'single quoted string\'
foo
bar
"double quoted string"
xyz
\'\'\'
single
quoted
multiline
text
\'\'\'
end
'
# Print the match result
str.scan(re) do |match|
puts match.to_s
end
Please keep in mind that these code samples are automatically generated and are not guaranteed to work. If you find any syntax errors, feel free to submit a bug report. For a full regex reference for Ruby, please visit: http://ruby-doc.org/core-2.2.0/Regexp.html