Нужно форматировать даты в динамически построенных WPF DataGrid

Мы связываем неизвестный набор результатов с WPF DataGrid во время выполнения. Некоторые из наших столбцов будут содержать значения DateTime, и нам необходимо правильно форматировать эти поля времени. Не зная, какие столбцы будут полями DateTime во время разработки, как мы можем форматировать столбцы во время выполнения?

Мы используем DataView для DataTable для привязки к DataGrid WPF.

как насчет

 

Я думаю, что это лучше, чем писать большие 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 

Смотри также: мой блог

  • Лисп форматирует символ несколько раз
  • Как отформатировать дату в angularjs
  • Формат Float до n знаков после запятой
  • Как преобразовать String в Date без знания формата?
  • строка printf, элемент переменной длины
  • Форматирование двух-двух знаков после запятой
  • Как использовать java.String.format в Scala?
  • Как получить формат строки даты (шаблон) в java?
  • Как преобразовать миллисекунды в читаемую человеком форму?
  • Как отредактировать частичный формат в Rails?
  • Как написать json с детьми из R
  • Давайте будем гением компьютера.