Форум программистов, компьютерный форум, киберфорум C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.74/34: Рейтинг темы: голосов - 34, средняя оценка - 4.74
1 / 1 / 0
Регистрация: 05.12.2014
Сообщений: 58
.NET 4.x

Как скрыть строки в dataGridView и отобразить всё обратно

27.04.2015, 11:25. Показов 7090. Ответов 11
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго времени суток! Подскажите как сделать правильно.
На форме есть checkBox и dataGridView.
При нажатии на checkBox в dataGridView остаются только строки (по условию), а остальные скрываются. При повторном нажатии на checkBox в dataGridView все строки отображаются вновь?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.04.2015, 11:25
Ответы с готовыми решениями:

Скрыть и отобразить несколько DataGridView
Добрый день! Так как с vb.net начал работать относительно недавно столкнулся с проблемкой: Есть форма, разбитая на 2 панели. В одной из...

DataGridView: как скрыть строки
Ребят, помогите пожалуйста. Такая проблема: Есть DataGridView. При нажатии кнопки поиск, определенные строчки должны становиться...

Как отобразить строки DataGridView в ComboBox
в DataGrid у меня в таблице имеются 10 строк Как эти строки отобразить в ComboBox ?

11
 Аватар для Sanya_sa
912 / 816 / 333
Регистрация: 03.02.2015
Сообщений: 5,276
Записей в блоге: 9
27.04.2015, 11:31
Цитата Сообщение от Serikbay Посмотреть сообщение
При нажатии на checkBox в dataGridView остаются только строки (по условию), а остальные скрываются.
А кто такие остальные??? Если скрыть все строки, что должно остаться.
0
1 / 1 / 0
Регистрация: 05.12.2014
Сообщений: 58
27.04.2015, 11:48  [ТС]
Цитата Сообщение от Sanya_sa Посмотреть сообщение
А кто такие остальные???
Которые не соответствуют условию(if(dataGridView1.Rows[i].Cells[1].Value.ToString() == "true")).

Цитата Сообщение от Sanya_sa Посмотреть сообщение
Если скрыть все строки, что должно остаться.
Которые соответствуют условию(if(dataGridView1.Rows[i].Cells[1].Value.ToString() == "true")).
0
 Аватар для Sanya_sa
912 / 816 / 333
Регистрация: 03.02.2015
Сообщений: 5,276
Записей в блоге: 9
27.04.2015, 11:53
В Вашем случаи хранить значения ячейки .Cells[1] для i-той строки в массиве. Обрабатывая событие checkBox перебирать массив и удалять или добовлять строки удовлетворяющие условию.

Добавлено через 1 минуту
Если у Вас dataGridView1 не привязан к источнику данных конечно.
1
1 / 1 / 0
Регистрация: 05.12.2014
Сообщений: 58
27.04.2015, 11:56  [ТС]
Цитата Сообщение от Sanya_sa Посмотреть сообщение
В Вашем случаи хранить значения ячейки .Cells[1] для i-той строки в массиве. Обрабатывая событие checkBox перебирать массив и удалять или добовлять строки удовлетворяющие условию.
Не совсем понятно.
Цитата Сообщение от Sanya_sa Посмотреть сообщение
Если у Вас dataGridView1 не привязан к источнику данных конечно.
Иногда привязан. (Я могу загрузить данные и с txt-файла и с БД)
0
 Аватар для Sanya_sa
912 / 816 / 333
Регистрация: 03.02.2015
Сообщений: 5,276
Записей в блоге: 9
27.04.2015, 12:33
Цитата Сообщение от Serikbay Посмотреть сообщение
Иногда привязан. (Я могу загрузить данные и с txt-файла и с БД)
Через dataGridView1.DataSource привязан? Или через bind? Или как?
Можно код глянуть?

Добавлено через 31 минуту
Кликните здесь для просмотра всего текста


C# Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
 
namespace DGV
{
    public partial class Form1 : Form
    {
        List<string> str = new List<string>();
        
        public Form1()
        {
            InitializeComponent();
            str.Add("true");
            str.Add("true");
            str.Add("false");
            str.Add("true");
            str.Add("true");
            str.Add("true");
            str.Add("false");
            str.Add("false");
            str.Add("true");
            str.Add("false");
            str.Add("false");
            str.Add("true");
            str.Add("true");
            str.Add("true");
 
            for (int i = 0; i < str.Count; i++)
            {
                dataGridView1.Rows.Add();
                dataGridView1.Rows[i].Cells[1].Value = str[i];
            }
        }
 
        private void checkBox1_CheckedChanged(object sender, EventArgs e)
        {
            if (checkBox1.Checked)
            {
                dataGridView1.Rows.Clear();
                 for (int i = 0; i < str.Count; i++)
                 {
                     if (str[i] == "true")
                     {
                         dataGridView1.Rows.Add();
                         dataGridView1.Rows[dataGridView1.Rows.Count - 2].Cells[1].Value = str[i];
                     }
                 }
            }
            else
            {
                dataGridView1.Rows.Clear();
                for (int i = 0; i < str.Count; i++)
                {
                    if (str[i] == "false")
                    {
                        dataGridView1.Rows.Add();
                        dataGridView1.Rows[dataGridView1.Rows.Count - 2].Cells[1].Value = str[i];
                    }
                }
            }
        }
    }
}
1
1 / 1 / 0
Регистрация: 05.12.2014
Сообщений: 58
27.04.2015, 13:15  [ТС]
Цитата Сообщение от Sanya_sa Посмотреть сообщение
Можно код глянуть?
C# Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
_sqlConnect = new SQLiteConnection(_connectString);
            _sqlConnect.Open();
            
            using (SQLiteCommand sqlCmd = new SQLiteCommand(cmd, _sqlConnect))
            {
                _adapter = new SQLiteDataAdapter();
                _adapter.SelectCommand = sqlCmd;
                _dataTable = new DataTable();
                _adapter.Fill(_dataTable);
                _source = new BindingSource();
                _source.DataSource = _dataTable;
                dataGrid.DataSource = _source;
                _adapter.Update(_dataTable);
            }
            
            _sqlConnect.Close();
Добавлено через 21 минуту
Это как с бд грузиться...
0
19 / 19 / 6
Регистрация: 09.12.2010
Сообщений: 140
28.04.2015, 20:12
А так не пойдет:

C# Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private void CheckBox_CheckedChanged(object sender, EventArgs e)
{
         if(CheckBox.Checked)
         {
              DataGridViewName.Columns["Name1"].Visible = false;
              DataGridViewName.Columns["Name2"].Visible = false;
         }
 
         else
         {
              DataGridViewName.Columns["Name1"].Visible = true;
              DataGridViewName.Columns["Name2"].Visible = true;
         }
 
}
Добавлено через 11 минут
а чтобы все скрыть/отобразить:
C# Скопировано
1
2
3
4
foreach (DataGridViewColumn column in DataGridViewName.Columns)
{
                column.Visible = false;
}
C# Скопировано
1
2
3
4
foreach (DataGridViewColumn column in DataGridViewName.Columns)
{
                column.Visible = true;
}
1
1 / 1 / 0
Регистрация: 05.12.2014
Сообщений: 58
29.04.2015, 09:08  [ТС]
Цитата Сообщение от sashocheck Посмотреть сообщение
А так не пойдет:
Думаю, что это не совсем то, что я спрашивал. Я спрашивал про строки, а у вас работа с колонками... Но всё равно спасибо!
0
471 / 234 / 73
Регистрация: 25.05.2012
Сообщений: 1,094
Записей в блоге: 1
29.04.2015, 11:30
Serikbay, я правильно понимаю, что ваш BindingSource _source существует только в контексте процедуры, заполняющей датагрид данными? Если вы объявите его за пределами этой процедуры, то впоследствии вы сможете применять к нему фильтры, в том числе и по чекбоксам.

C# Скопировано
1
2
string filter_string = "условие отбора";
_source.Filter = string.Format("[имя колонки] = ({0})", filter_string);
2
1 / 1 / 0
Регистрация: 05.12.2014
Сообщений: 58
29.04.2015, 21:50  [ТС]
NewOrdered, Спасибо.
0
471 / 234 / 73
Регистрация: 25.05.2012
Сообщений: 1,094
Записей в блоге: 1
29.04.2015, 22:12
Serikbay, вот как рекомендует делать привязку данных сам Майкрософт:
https://msdn.microsoft.com/ru-... .100).aspx
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.04.2015, 22:12
Помогаю со студенческими работами здесь

Как в DataGridView отобразить удаленные строки?
Здравствуйте! Как в DataGridView, пришитому DataSource'ом к DataTable показать все строки этого самого DataTable , в т.ч. и...

Скрыть на рабочем столе всё и потом вернуть обратно
Можно ли как-то свернуть все окна, скрыть все ярлыки и даже строку с пуском? Т.е. чтобы на экране осталась только фоновая картинка и всё. А...

Скрыть/отобразить строки в списке
Здравствуйте! Пишу код для кнопочки (Access), которая должна будет скрывать/отображать строки, у которых значение в поле (по которому идет...

Как в datagridview отобразить две длинные строки одна после другой, но без сворачивания
Добрый день! Нужно в ряде datagridview отобразить две длинные строки, одна после другой, и чтобы при этом не делалось сворачивание...

Как отобразить таблицу из Базы данных ms access в DataGridView программным путём?(написав всё в коде)
Здравствуйте. Как отобразить таблицу из Базы данных ms access в DataGridView программным путём?(написав всё в коде) Я что-то попытался...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Lazarus. Таблица с объединением ячеек.
Massaraksh7 21.03.2025
Понадобилась представление на экране таблицы с объединёнными ячейками. И не одной, а штук триста, и все разные. На Delphi я использовал для этих целей TStringGrid, и то, кривовато получалось. А в. . .
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
Колмогоровская сложность: Приёмы упрощения кода
ArchitectMsa 20.03.2025
Наверное, каждый программист хотя бы раз сталкивался с кодом, который напоминает запутанный лабиринт — чем дальше в него погружаешься, тем сложнее найти выход. И когда мы говорим о сложности кода, мы. . .
PostgreSQL в Kubernetes: Подготовка кластера и настройка
Mr. Docker 20.03.2025
Когда доходит до контейнеризации баз данных и особенно таких требовательных к ресурсам системах как PostgreSQL, многие команды до сих пор колеблются, прежде чем перенести их в контейнерную. . .
C++26: Индексирование пакетов и метапрограммиро­вание
bytestream 20.03.2025
Эволюция C++ продолжается стремительными темпами – каждый новый стандарт приносит функциональность, о которой мы мечтали годами. Звучит слишком громко? Если вы когда-либо боролись с вариадическими. . .
Состояние гонки в C#: подводные камни многопоточного программировани­я
UnmanagedCoder 20.03.2025
Что такое состояние гонки? Это ситуация, когда результат программы непредсказуемо меняется в зависимости от порядка выполнения потоков. Проще говоря, два или более потока пытаются одновременно. . .
Next.js для разработки React: преимущества серверного рендеринга
Reangularity 20.03.2025
Next. js решает классическую проблему React-приложений: медленную первоначальную загрузку и плохую индексацию поисковиками. Вместо того чтобы заставлять браузер пользователя выполнять всю работу по. . .
JUnit или TestNG: Выбираем Java-фреймворк для тестирования
Javaican 20.03.2025
История тестовых фреймворков в Java началась в конце 90-х, когда Кент Бек и Эрих Гамма разработали JUnit - инструмент, который перевернул представление разработчиков о модульном тестировании. JUnit. . .
Разбиваем монолит на два микросервиса и реализуем CI/CD
ArchitectMsa 20.03.2025
Когда команда растет, а функциональность монолита расширяется, поддерживать и развивать такую систему становится все труднее. Разработчики начинают тратить много времени на разбор сложных. . .
Python и PDF: Создание и редактирование файлов
py-thonny 20.03.2025
Работа с PDF-документами – одна из популярных задач в современной разработке. Python предлагает несколько инструментов для создания, чтения и редактирования PDF-файлов, среди которых особенно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер