Как заменить все десятичные разделители в тексте на собственный разделитель?
Примеры:
xyz,1,23.4yz должен быть с точкой-разделителем xyz,1.23.xyzxyz,1.23.4yz должен быть с разделителем-запятой xyz,1,23.xyzЯ написал для него этот тестовый пример:
[Theory]
[InlineData("0,05 - 2", "0,05 - 2", "0.05 - 2")]
[InlineData("0,1 ,5", "0,1 ,5", "0.1 ,5")]
[InlineData("0,1 - 2,0", "0,1 - 2,0", "0.1 - 2.0")]
[InlineData("0,234", "0,234", "0.234")]
[InlineData("123,4", "123,4", "123.4")]
[InlineData("12.345,6789", "12,345,6789", "12.345.6789")]
[InlineData("xyz,1,23.4yz", "xyz,1,23,4yz", "xyz,1.23.4yz")]
[InlineData("xyz5,1,23,xyz", "xyz5,1,23,xyz", "xyz5.1.23,xyz")]
[InlineData("0.05 - 2", "0,05 - 2", "0.05 - 2")]
[InlineData("0.1 .5", "0,1 .5", "0.1 .5")]
[InlineData("0.1 - 2.0", "0,1 - 2,0", "0.1 - 2.0")]
[InlineData("0.234", "0,234", "0.234")]
[InlineData("123.4", "123,4", "123.4")]
[InlineData("12345.6789", "12345,6789", "12345.6789")]
[InlineData("xyz.1.23.4yz", "xyz.1,23,4yz", "xyz.1.23.4yz")]
[InlineData("xyz5,1.23,xyz", "xyz5,1,23,xyz", "xyz5.1.23,xyz")]
public void Convert(string input, string resultComma, string resultDot)
{
string expectedResultComma = new ConverterDecimal(",").Convert(input);
expectedResultComma.Should().Be(resultComma);
string expectedResultDot = new ConverterDecimal(".").Convert(input);
expectedResultDot.Should().Be(resultDot);
}
Единственное решение, которое я знаю, - это проверять каждое "слово", если это число, и анализировать его до десятичного числа. Мне интересно, что я не нашел решения для этого вопроса :)
И исходный пример xyz,1,23.4yz не соответствует выходу xyz,1,23.4yz. 4 был заменен на x. Вы должны четко понимать примеры и правила, которые вам нужны.
Чем больше смотрю на ваши примеры, тем больше путаюсь. Не могли бы вы прочитать Как спросить, а затем действительно очень точно описать свое правило?
Данные для теста дают входную строку, затем ожидаемый результат для преобразования в запятую, а затем для разделителя точек для десятичных значений. Я тоже запутался в этой задаче :)
Я добавил второй пример. Надеюсь, теперь это более понятно @Enigmativity





Попробуем сформулировать задачу иначе; по приведенным примерам, мы, вероятно, можем выразить это как
Replace every comma
,which is surrounded by digits0..9into dot.
Если это ваш случай, вы можете попробовать обычные выражения, мы можем попробовать шаблон (?<=[0-9]),(?=[0-9]):
(?<=[0-9]) - look behind for 0..9 digit
, - comma
(?=[0-9]) - look ahead for 0..9 digit
Код:
using System.Text.RegularExpressions;
...
private static string ConvertMe(string source) =>
Regex.Replace(source, @"(?<=[0-9]),(?=[0-9])", ".");
Демо:
string[] tests = new string[] {
"0,05 - 2",
"0,1 ,5",
"0,1 - 2,0",
"0,234",
"123,4",
"12.345,6789",
"xyz,1,23.4yz",
"xyz5,1,23,xyz",
"0.05 - 2",
"0.1 .5",
"0.1 - 2.0",
"0.234",
"123.4",
"12345.6789",
"xyz.1.23.4yz",
"xyz5,1.23,xyz",
};
string report = string.Join(Environment.NewLine, tests
.Select(test => $"{test,20} : {ConvertMe(test)}"));
Console.Write(report);
Исход:
0,05 - 2 : 0.05 - 2
0,1 ,5 : 0.1 ,5
0,1 - 2,0 : 0.1 - 2.0
0,234 : 0.234
123,4 : 123.4
12.345,6789 : 12.345.6789
xyz,1,23.4yz : xyz,1.23.4yz
xyz5,1,23,xyz : xyz5.1.23,xyz
0.05 - 2 : 0.05 - 2
0.1 .5 : 0.1 .5
0.1 - 2.0 : 0.1 - 2.0
0.234 : 0.234
123.4 : 123.4
12345.6789 : 12345.6789
xyz.1.23.4yz : xyz.1.23.4yz
xyz5,1.23,xyz : xyz5.1.23,xyz
Основываясь на ответе @dmitry-bychenko, я придумал это решение для запятой и точки в качестве разделителей:
public string Convert(string input, string separator)
{
string oldSeparator;
if (separator.Equals("."))
{
oldSeparator = ",";
}
else
{
oldSeparator = ".";
}
var result = Regex.Replace(input, $@"(?<=[0-9])\{oldSeparator}(?=[0-9])", separator);
return result;
}
В вашем примере
xyz,1.23.xyzвсе еще есть запятая. Какое правило вы пытаетесь внедрить?