Я пишу простую программу на C # с использованием wpf, подобия базы, я понимаю, что эту проблему было бы проще решить с помощью subd и entity framework, но дело в том, что вам нужно решить этот способ

Итак, у меня есть текстовый файл, из которого мне нужно загрузить данные в сетку дат.

У меня есть класс, описывающий строку из этого текстового файла, вот он:

public class Student
{
    public int Id { get; set; }
    public string Name { get; set; }
    public string LastName { get; set; }
    public string MidName { get; set; }
    public int Informatics { get; set; }
    public int Maths { get; set; }
    public int Physics { get; set; }
    public double Score { get; set; }
}

Поле оценок для данных программы (среднее арифметическое оценок учащегося)

И у меня есть datagrid, в котором мне нужно выводить данные:

<DataGrid x:Name="DGridStudents" IsReadOnly="True" AutoGenerateColumns="False" HorizontalAlignment="Left" Height="329" Margin="57,15,0,0" VerticalAlignment="Top" Width="736">
        <DataGrid.Columns>
            <DataGridTextColumn Header="ID" Width="*" Binding="{Binding Id}"/>
            <DataGridTextColumn Header="Name" Width="*" Binding="{Binding Name}"/>
            <DataGridTextColumn Header="LastName" Width="*" Binding="{Binding LastName}"/>
            <DataGridTextColumn Header="MidName" Width="*" Binding="{Binding MidName}"/>
            <DataGridTextColumn Header="Informatics" Width="*" Binding="{Binding Informatics}"/>
            <DataGridTextColumn Header="Maths" Width="*" Binding="{Binding Maths}"/>
            <DataGridTextColumn Header="Physics" Width="*" Binding="{Binding Physics}"/>
            <DataGridTextColumn Header="Score" Width="*" Binding="{Binding Score}"/>
        </DataGrid.Columns>
    </DataGrid>

Таким образом, раньше я заполнял DataGrid, теперь мне нужно было добавить поле Score (Среднее арифметическое оценок по предметам)

List<Student> list = new List<Student>();
            using (StreamReader sr = new StreamReader(fileName, true))
            {
                
                string line;
                while ((line = sr.ReadLine()) != null)
                {
                    var parsed = line.Split(' ');
                    list.Add(new Student
                        (
                           Convert.ToInt32(parsed[0]),
                           parsed[1],
                           parsed[2],
                           parsed[3],
                           Convert.ToInt32(parsed[4]),
                           Convert.ToInt32(parsed[5]),
                           Convert.ToInt32(parsed[6])
                        ));
                }
            }
            DGridStudents.ItemsSource = list;

Скажите, пожалуйста, как я могу сделать это с помощью привязок данных без использования шаблона MVVM?

Пример строки из текстового файла:

1 Бенедикт Тимоти-Карлтон Камбербэтч 5 5 5

-2
roxyashechka 27 Фев 2021 в 22:05

2 ответа

Лучший ответ

Если вы пытаетесь объединить значения каждого столбца, вы можете использовать MultiBinding.

Вот пример:

<DataGridTextColumn Header="Your Header">
    <DataGridTextColumn.Binding>
                        
        <!-- 
            Your string format here.
            This will put a space between each value.
        -->
        <MultiBinding StringFormat="{}{0} {1} {2} {3} {4} {5} {6} {7}">

            <!-- Your bindings... -->
            <MultiBinding.Bindings>
                <Binding Path="Id" />
                <Binding Path="Name" />
                <Binding Path="LastName" />
                <Binding Path="MidName" />
                <Binding Path="Informatics" />
                <Binding Path="Maths" />
                <Binding Path="Physics" />
                <Binding Path="Score" />
            </MultiBinding.Bindings>
        </MultiBinding>
    </DataGridTextColumn.Binding>

</DataGridTextColumn>

РЕДАКТИРОВАТЬ:

Думаю, я неправильно понял, что это за строка из вашего текстового файла. Если вы хотите произвести какой-то расчет, вы можете создать конвертер.

Вот пример математического преобразователя, у которого есть свойство Operation, определяющее, что делать.

  • Этот конвертер предназначен для выполнения математических операций только с двумя значениями - вам нужно будет написать свой код, чтобы учесть то, что вам нужно.
public sealed class MathMultipleConverter : IMultiValueConverter
{
    #region Converter Properties
        
    public MathOperation Operation { get; set; }

    #endregion

    public object Convert(object[] value, Type targetType, object parameter, CultureInfo culture)
    {
        //  Do you calculations here...

        if (value == null || value.Length < 2 || 
            value[0] == null || value[1] == null) 
            return Binding.DoNothing;

        if (!double.TryParse(value[0].ToString(), out double value1) || 
            !double.TryParse(value[1].ToString(), out double value2))
            return 0;

        switch (Operation)
        {
            default:
                return value1 + value2;
            case MathOperation.Divide:
                return value1 / value2;
            case MathOperation.Multiply:
                return value1 * value2;
            case MathOperation.Subtract:
                return value1 - value2;
        }
    }

    public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture)
    {
        throw new NotImplementedException();
    }
}

Применение:

  1. Ссылка на конвертер где-нибудь в ваших ресурсах. Я установил для свойства Operation значение Multiply.
<UserControl.Resources>
        <converters:MathMultipleConverter x:Key="MathMultipleConverter" Operation="Multiply" />
</UserControl.Resources>
  1. Используйте его в своем MultiBinding.
<DataGridTextColumn Header="Your Header">
    <DataGridTextColumn.Binding>

        <!-- Your Converter -->
        <MultiBinding Converter="{StaticResource MathMultipleConverter}">

            <!-- Your bindings... -->
            <MultiBinding.Bindings>
                <Binding Path="Maths" />
                <Binding Path="Physics" />
            </MultiBinding.Bindings>
        </MultiBinding>
    </DataGridTextColumn.Binding>
</DataGridTextColumn>
0
Brxndxn 27 Фев 2021 в 20:47
var student = new Student
                        {
                            Id = Convert.ToInt32(parsed[0]),
                            Name = parsed[1],
                            LastName = parsed[2],
                            MidName = parsed[3],
                            Informatika = Convert.ToInt32(parsed[4]),
                            Matematika = Convert.ToInt32(parsed[5]),
                            Fizika = Convert.ToInt32(parsed[6]),
                            Score = 5
                        };
                        list.Add(student);
0
roxyashechka 27 Фев 2021 в 19:35