I am reading a string ID value from a table. When the ID was input by the user, it was done with an input mask that the user defined, so the mask could have been something like 000-00-0000
, ##-######
, AA-9999999
, etc. The mask will vary by user, and so must be evaluated at runtime.
Given that only the alphanumeric text is stored in the table, what is the best way of generating a new string with that mask applied?
For example:
Table value = "123456789"
If user has defined mask of 000-00-0000
, I want to get string 123-45-6789
.
If user has defined mask of AA-9999999
, I want to get string 12-3456789
.
If user has defined mask of FR999_999999
, I want to get string FR123_456789
.
It seems like the mask pattern is that it will insert matching dashes for every dash in the mask. If that's the case then this should work.
public static string MaskValue(string mask, string value) {
var builder = new System.Text.StringBuilder();
var maskIndex = 0;
var valueIndex = 0;
while (maskIndex < mask.Length && valueIndex < value.Length) {
if (mask[maskIndex] == '-') {
builder.Append('-');
maskIndex++;
} else {
builder.Append(value[valueIndex]);
maskIndex++;
valueIndex++;
}
}
// Add in the remainder of the value
if (valueIndex + 1 < value.Length) {
builder.Append(value.Substring(valueIndex);
}
return builder.ToString();
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With