Нужно форматировать даты в динамически построенных WPF DataGrid
Мы связываем неизвестный набор результатов с WPF DataGrid во время выполнения. Некоторые из наших столбцов будут содержать значения DateTime, и нам необходимо правильно форматировать эти поля времени. Не зная, какие столбцы будут полями DateTime во время разработки, как мы можем форматировать столбцы во время выполнения?
Мы используем DataView для DataTable для привязки к DataGrid WPF.
- Как печатать двойной с двумя десятичными знаками в Android?
- Где спецификатор формата DateTime 'Z'?
- Форматирование двух-двух знаков после запятой
- Как преобразовать миллисекунды в читаемую человеком форму?
- Как вы форматируете дату и время в Android?
- Формат Float до n знаков после запятой
- Как выводить сериализованные данные представления JSON в виде массива объектов, а не обертывать внешний объект?
- Как преобразовать String в Date без знания формата?
- Как отформатировать DateTime до 24 часов?
- Изменение формата даты на yyyy-mm-dd
- Как получить выбранный пользователем формат даты в Android?
- Как форматировать вывод печати или строку в фиксированную ширину?
- Изменение формата даты в R
как насчет
Я думаю, что это лучше, чем писать большие fragmentы кода
Я понял, как это сделать в коде … надеюсь, есть способ имитировать это в XAML. (Пожалуйста, напишите, если вы найдете рабочий образец XAML.)
Чтобы выполнить это в коде, добавьте обработчик событий для события AutoGeneratingColumn Grid, например:
private void ResultsDataGrid_AutoGeneratingColumn(object sender, DataGridAutoGeneratingColumnEventArgs e) { if (e.PropertyType == typeof(DateTime)) { DataGridTextColumn dataGridTextColumn = e.Column as DataGridTextColumn; if (dataGridTextColumn != null) { dataGridTextColumn.Binding.StringFormat = "{0:d}"; } } }
Эй, вы можете установить информацию о культуре локали в конструкторе формы WPF как
this.Language = XmlLanguage.GetLanguage (CultureInfo.CurrentCulture.IetfLanguageTag);
Или вы можете включить разметку xml xml: lang = “en-GB” в разметке заголовка windows
Я бы использовал DataTemplate с DataType Date или DateTime (в зависимости от того, как он будет проходить через). Поместите TextBlock в DataTemplate с помощью StringFormat в привязке.
Что-то вроде этого должно работать (непроверено)
Или, если вы хотите, чтобы он применялся только в сетке
...
dataGridTextColumn.Binding.StringFormat = “{0: dd / MM / yyyy}”;
работал красиво
Я запускаю этот путь. его работа завершена.
Ответ FarrEver, 11 мая, хорош, но мне это не действует. Я все еще получаю американский миллион / дд / гггг вместо моего немецкого dd / mm / yyyy. Поэтому я предлагаю найти региональные настройки компьютера и использовать его в StringFormat
Private Sub DGrid_AutoGeneratingColumn(ByVal sender As System.Object, ByVal e As Microsoft.Windows.Controls.DataGridAutoGeneratingColumnEventArgs) If e.PropertyType Is GetType(DateTime) Then Dim dataGridTextColumn As DataGridTextColumn = TryCast(e.Column, DataGridTextColumn) If dataGridTextColumn IsNot Nothing Then Dim ShortDatePattern As String = System.Globalization.DateTimeFormatInfo.CurrentInfo.ShortDatePattern dataGridTextColumn.Binding.StringFormat = "{0:" + ShortDatePattern + "}" '"{0:dd/MM/yyyy}" End If End If End Sub
Смотри также: мой блог