# If you'd like to omit non-matching lines from the result; add ';d' to the end of the expression.
sed -E 's/<div>((?:<div[^>]*>(?1)<\\/div>|[^<]*|<(?!div))*)<\\/div>/<p>$1<\/p>/msig;t' <<< "<div>
Lorem ipsum dolor sit amet
</div>
<div>
Lorem ipsum dolor sit amet
</div>
<div>
<div class=\"media_embed\">
<div style=\"xxx\">
<div style=\"xxx\">
<div style=\"xxx\"></div>
</div>
</div>
</div>
</div>
<div>
Lorem ipsum dolor sit amet
</div>
<div class=\"foo\">
<div>FOO</div>
<div class=\"bar\">
<div>BAR</div>
</div>
<div>FOOBAR<div class=\"foobar\"></div></div>
<div class=\"bar\"><div><b>BAR</b></div></div>
<!-- para este caso, deberás ejecutar preg_replace
hasta que no haya nada nuevo por reemplazar -->
<div><div>foobar</div></div>
</div>"
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