# If you'd like to omit non-matching lines from the result; add ';d' to the end of the expression.
sed -E 's/(?:
#start by finding the initial position of the table start, in order to store the match position for \G
TABLE\n\K|
#after we've found the table head, continue matching using this position. make sure we arent at the beginning of the string
\G(?<!^)
)
#capture the data we're interested in
(?:
#make sure there is no 'END' in the string
(?!END)
#match everything until the line ending
.
)*
#consume the newline at the end of the string
\n/%\0/g;t' <<< ""
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 SED, please visit: https://www.gnu.org/software/sed/manual/html_node/The-_0022s_0022-Command.html