I would need to remove anything between XML tags, especially whitespace and newlines.
For example removing whitespace and newslines from:
\\n<
A solution is to select all "blank" text nodes and remove them.
doc = Nokogiri(xml_source)
doc.xpath('//text()[not(normalize-space())]').remove
Don't use regex. Try parsing the XML into a DOM, and manipulating from there (what language/framework are you using?);
Please don't use regular expressions to parse XML. It's horribly error prone.
Use a proper XML library, which will make this trivial. There are XML libraries available for just about every programming platform you could ask for - there's really no excuse to use a regular expression for XML.
You shouldn't use regex to parse XML or HTML, it's just not reliable and there are way too many edge cases. You should use a XML/HTML parser for this kind of stuff instead.
It is generally not a good idea to parse XML using regular expressions. One of the major benefits of XML is that there are dozens of well-tested parsers out there for any language/framework that you might ever want. There are some tricky rules within XML that prevent any regular expression from being able to properly parse XML.
That said, something like:
s/>.*?</></gs
(that is perl syntax) might do what you want. That says take anything from a greater than up to a less than, and strip it away. The "g" at the end says to perform the substitution as many times as needed, and the "s" makes the "." match all characters INCLUDING newlines (otherwise newlines would not be included, so the pattern would need to be run once for each line, and it would not cover tags that span multiple lines).