I have an indented JSON string e.g.
{
\"a\": 1
}
However, I don\'t have the type of the instance to be serialized or deserialized.
That regex below works for me.
string json = @"{
"window": {
"title": "Sample Konfabulator Widget",
"name": "main_window",
"width": 500,
"height": 500
}
}"
Regex.Replace(json, @"\s(?=([^""]*""[^""]*"")*[^""]*$)", string.Empty);
I am using it on .NET Core app project. Regex is from that answer.
Regex.Replace(myJSON, "(\"(?:[^\"\\\\]|\\\\.)*\")|\\s+", "$1")
should do it. It makes sure that strings that contain space characters are preserved, and all other space characters are discarded. All JSON keywords (false, true, null) have to be separated by commas or other punctuation so only white-space inside strings needs to be preserved.
The first option (\"(?:[^\"\\\\]|\\\\.)*\") matches a double quoted string. The (...) mean that the output is captured and available in the replacement as $1. The [^\"\\\\] matches any character except a double quote or escape character \.
Since matching occurs left-to-right, the second option, \s+ will not match space inside a string.
So we match whole strings, and spaces outside strings. In the former case, $1 is the string token, and in the latter case $1 is the empty string because group 1 was not used.
This works as intended because
var x=0 is different from varx=0 and x - -(y) is different from x--(y).