Условная оптимизация / удобочитаемость

#c# #asp.net-mvc #if-statement #optimization

#c# #asp.net-mvc #if-оператор #оптимизация

Вопрос:

В настоящее время у меня есть контроллер, который считывает текстовый файл, проверяет данные, а затем выводит их в представление. Мне было интересно, может ли быть лучший способ выполнить мою проверку?

Здесь я читаю свой файл и выполняю свои проверки. Как вы можете видеть, моя проверка довольно длинная, и после того, как я добавлю еще 3 или 4 условия if else, она может оказаться нечитаемой, если ее еще нет. Любые предложения будут оценены!

 using (var sr = new StreamReader(newFullPath))
{
    while ((strbuild = sr.ReadLine()) != null)
    {
        var strArray = strbuild.Split('|');
        string INum = string.Empty,
            IDate = string.Empty,
            site = string.Empty,
            PG = string.Empty,
            errors = string.Empty;

        if (strArray[0] == "1")
        {
            FileCheck(strArray, out INum, out IDate, out site, out PG, out errors);
            var model = new UploadFileValidation
            {
                InvoiceNumber = INum,
                Errors = errors
            };
            validateOutput.Add(model);
        }
    }

    return View(validateOutput);
}
  

Проверка приведена ниже

 private void FileCheck(string[] strArray, out string INum, out string IDate, out string site, out string PG, out string errors)
{
    INum = strArray[1];
    IDate = strArray[2];
    errors = "";
    site = strArray[10];
    var check = strArray.ElementAtOrDefault(11) != null;
    if (check)
        PG = strArray[11];
    else
        PG = "";
    string[] errorformats = { $"Unsupported date format of {IDate}.", "Site is missing", "Invalid Pay group" };
    string[] format = { "MM/dd/yyyy", "M/dd/yyyy", "MM/d/yyyy", "M/d/yyyy" };
    DateTime dateTime;
    if (!DateTime.TryParseExact(IDate, format, CultureInfo.InvariantCulture,
DateTimeStyles.None, out dateTime))
        errors = $"{errorformats[0]}";
    if (PG == "" amp;amp; errors != "")
        errors = $"{errors}<br>{errorformats[2]}";
    else if (PG == "" amp;amp; errors == "")
        errors = $"{errors}<br>{errorformats[1]}";
    if (site == "" amp;amp; errors != "")
        errors = $"{errors}<br>{errorformats[1]}";
    else if (site == "" amp;amp; errors == "")
        errors = $"{errorformats[1]}";
}
  

Вот конечный результат
Пример

Ответ №1:

Вы можете использовать string.Join для объединения нескольких ошибок с <br> :

 private void FileCheck(string[] strArray, out string invoiceNum, out string date, out string site, out string pg, out string errorMessage)
{
    var errors = new List<string>();

    invoiceNum = strArray[1];
    date = strArray[2];
    site = strArray[10];
    pg = strArray.ElementAtOrDefault(11) ?? string.Empty;

    var validDateFormats = new[] { "MM/dd/yyyy", "M/dd/yyyy", "MM/d/yyyy", "M/d/yyyy" };
    if (!DateTime.TryParseExact(date, validDateFormats, CultureInfo.InvariantCulture, DateTimeStyles.None, out _))
        errors.Add($"Unsupported date format of {date}.");

    if (pg == "")
        errors.Add("Invalid Pay group");

    if (site == "")
        errors.Add("Site is missing");

    errorMessage = string.Join("<br>", errors);
}
  

Если вас не волнует результат an out , вы можете просто использовать out _ , чтобы игнорировать его. Вы даже можете игнорировать несколько из них, например:

 FileCheck(strArray, out var invoiceNum, out _, out _, out _, out var errors);
  

Комментарии:

1. Это определенно намного чище. Большое вам спасибо!