Кнопка поиска в DataGridView с измененным текстовым полем - PullRequest
0 голосов
/ 03 января 2019

Я хочу сделать кнопку поиска в DataGridView. Я читаю свои данные с этим кодом:

private void button1_Click_1(object sender, EventArgs e)
                {
                    FileStream f1 = new FileStream("zapis.dat", FileMode.Open);
                    BinaryReader br = new BinaryReader(f1);
                    int а = 0;
                    while (f1.Position < f1.Length)
                    {
                        string data = br.ReadString();
                        string sing = br.ReadString();
                        string avtor = br.ReadString();
                        string zagl = br.ReadString();
                        string janr = br.ReadString();
                        string ezik = br.ReadString();
                        dataGridView1.Rows.Add(++а, ezik, zagl, avtor, janr, sing, data);
                    }
                    f1.Close();
                }

Я пытаюсь сделать кнопку с кодом:

private void textBox1_TextChanged (отправитель объекта, EventArgs e)

  if (string.IsNullOrEmpty(textBox1.Text))
        {
            (dataGridView1.DataSource as DataTable).DefaultView.RowFilter = string.Empty;
        }
        else
        {
            (dataGridView1.DataSource as DataTable).DefaultView.RowFilter = string.Format("Name='{0}'", textBox1.Text);
        }
    }

но когда я начал, я получаю ошибку: System.NullReferenceException: 'Ссылка на объект не установлена ​​для экземпляра объекта.'

(... as System.Data.DataTable) returned null.

на:

else
                                {
                                    (dataGridView1.DataSource as DataTable).DefaultView.RowFilter = string.Format("Name='{0}'", textBox1.Text);

Как я могу это исправить?

1 Ответ

0 голосов
/ 03 января 2019

Вы не используете DataTable в качестве источника данных для DataGridView.

Используйте класс для представления ваших данных, тогда вы сможете выполнять работу без «тяжелой» DataTable.

public class Item
{
    public string Data { get; set; }
    public string Sing { get; set; }
    public string Avtor { get; set; }
    // and so on ...
}

// Save data into private class member
private List<Item> _loadedData = new List<Item>();

private void button1_Click_1(object sender, EventArgs e)
{
    using (var stream  = new FileStream("zapis.dat", FileMode.Open))
    using (var reader = new BinaryReader(stream))
    {
        var data = new List<Item>();
        while (stream.Position < stream.length)
        {
            var item = new Item
            {
                Data = reader.ReadString(),
                Sing = reader.ReadString(),
                Avtor = reader.ReadString()
            };
            data.Add(item)
        }

        // update private member with newly loaded data
        _loadedData = data;
    }

    // Bind loaded data to the DataGridView
    datagridview1.DataSource = _loadedData;
}

Фильтрация может быть выполнена простым Where методом для _loadedData коллекции.

private void textBox1_TextChanged(object sender, EventArgs e)
{
    var filtered = _loadedData.Select(item => item);
    if (string.IsNullOrEmpty(textBox1.Text) == false)
    {
        filtered = filtered.Where(item => item.Avtor == textBox1.Text);
    }

    datagridview1.DataSource = filtered.ToList();
}
...