winforms - проблема редактирования временного интервала ячейки gridview - PullRequest
1 голос
/ 04 января 2011

Я слежу за этим вопросом для форматирования значения временного интервала в сетке.

Форматирование TimeSpan в столбце DataGridView

Я набираю значение только минут в сетке следующим образом

DataGridViewColumn idleTimeColumn = myGridView.Columns["IdleTime"];
idleTimeColumn.DefaultCellStyle.FormatProvider = new TimeSpanFormatter();
idleTimeColumn.DefaultCellStyle.Format = "m";

Эта ячейка является редактируемой, поэтому, когда я вписываю 5 (то есть 5 минут) в ячейку, это должно занять минуту, но в качестве значения дня (т.е. 5,00: 00: 00).

Я пробовал разные значения для формата (мм,% m), но все это дает одинаковый вывод.

Ответы [ 3 ]

2 голосов
/ 19 января 2011

Необходимо реализовать функцию для анализа входного значения.

TimeSpanFormatter может использоваться для преобразования связанных данных TimeSpan в форматированную строку для отображения.Но он не может преобразовать входное значение в TimeSpan.Необходимо преобразовать входное значение в обработчик событий DataGridView.CellParsing.

Ниже приведен пример кода для анализа входного значения.

Обработчик событий DataGridView.CellParsing

private void dataGridView1_CellParsing(object sender, DataGridViewCellParsingEventArgs e)
{
    if (e.DesiredType == typeof(TimeSpan))
    {
        TimeSpanParser parser = new TimeSpanParser();
        e.Value = parser.Parse(e.Value.ToString(), e.InheritedCellStyle.Format);
        e.ParsingApplied = true;
    }
}

Класс TimeSpanParser

public class TimeSpanParser
{
    private Regex formatParser;

    private List<TimeSpanPart> parts;

    public TimeSpanParser()
    {
        this.formatParser = new Regex("d{1,2}|h{1,2}|m{1,2}|s{1,2}|f{1,7}", RegexOptions.Compiled);
        this.parts = new List<TimeSpanPart>();
    }

    public TimeSpan Parse(string input, string format)
    {
        this.parts.Clear();
        var pattern = this.formatParser.Replace(format, m => ReplaceFormat(m));
        var match = Regex.Match(input, "^" + pattern + "$");

        TimeSpan result = new TimeSpan();
        for (int i = 1; i < match.Groups.Count; i++)
        {
            var value = Convert.ToDouble(match.Groups[i].Value);
            switch (this.parts[i - 1])
            {
                case TimeSpanPart.Day:
                    result = result.Add(TimeSpan.FromDays(value));
                    break;
                case TimeSpanPart.Hour:
                    result = result.Add(TimeSpan.FromHours(value));
                    break;
                case TimeSpanPart.Minute:
                    result = result.Add(TimeSpan.FromMinutes(value));
                    break;
                case TimeSpanPart.Second:
                    result = result.Add(TimeSpan.FromSeconds(value));
                    break;
                case TimeSpanPart.Millisecond:
                    int digit = match.Groups[i].Value.Length;
                    value =value * Math.Pow(10, 3 - digit);
                    result = result.Add(TimeSpan.FromMilliseconds(value));
                    break;
            }
        }

        return result;
    }

    private string ReplaceFormat(Match match)
    {
        switch (match.Value)
        {
            case "dd":
            case "d":
                this.parts.Add(TimeSpanPart.Day);
                return "(\\d{1,2})";
            case "hh":
            case "h":
                this.parts.Add(TimeSpanPart.Hour);
                return "(\\d{1,2})";
            case "mm":
            case "m":
                this.parts.Add(TimeSpanPart.Minute);
                return "(\\d{1,2})";
            case "ss":
            case "s":
                this.parts.Add(TimeSpanPart.Second);
                return "(\\d{1,2})";
            case "fffffff":
            case "ffffff":
            case "fffff":
            case "ffff":
            case "fff":
            case "ff":
            case "f":
                this.parts.Add(TimeSpanPart.Millisecond);
                return "(\\d{1,7})";
            default:
                return match.Value;
        }
    }
}

Перечисление TimeSpanPart

public enum TimeSpanPart
{
    Day,
    Hour,
    Minute,
    Second,
    Millisecond,
}
0 голосов
/ 14 января 2011

Я полагаю, вы правильно обрабатываете событие форматирования ячейки

Вы ссылались на это, я думаю,

0 голосов
/ 04 января 2011

Попробуйте mm или %m вместо m; idleTimeColumn.DefaultCellStyle.Format = "mm";

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...