Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552

Вывод информации из .txt в DataGridView

20.07.2018, 13:28. Показов 3448. Ответов 29
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день может кто сможет подсказать. Читаю из файла информацию и вывожу это все в datagridview.
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
 StreamReader myRead = new StreamReader(@"C:\Users\CRIT\Desktop\movements.TXT", System.Text.Encoding.Default);
                string[] str;
                int num = 0;
                try
                {
 
                    string[] str1 = myRead.ReadToEnd().Split('\n');
                    num = str1.Count();
                    dataGridView1.RowCount = num + 1;
                    for (int i = 0; i < num; i++)
                    {
                        {
 
                            str = str1[i].Split('=');
                            for (int j = 0; j < dataGridView1.ColumnCount; j++)
                            {
                                try
                                {
                                    dataGridView1.Rows[i].Cells[j].Value = str[j];
                                }
 
                                catch (Exception ex)
                                {
                                    MessageBox.Show(ex.Message);
                                }
                            }
                        }
                    }
                }
 
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
дело в том что читается все в заноситься в одну колонку, а нода чтоб гурбо говоря название колонок из файла до знака равноа содержимое после.

Добавлено через 8 минут
пробовал так же через
C#
1
2
3
  StreamReader reader = new StreamReader(@"C:\Users\CRIT\Desktop\movements.TXT");
            List<Table> Tables = new List<Table>();
            dataGridView1.DataSource = Tables;
но тут вопрос про распределение по столбцам
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.07.2018, 13:28
Ответы с готовыми решениями:

Вывод информации в DataGridView в зависимости от выбора в другом DataGridView - C# Access
В 1м DataGridView У меня предприятия, при выборе какого-то 1 предприятия, во 2й DataGridView появляются все записи с тем же ключом. Общий...

Вывод информации в DataGridView в зависимости от выбора в другом DataGridView
Прошу прощения сразу же потому что видел много тем похожих, но ответа так и не могу найти. Есть два датагрида, к первому привязана таблица...

Считывание информации из txt файла и запись в dataGridView
В файле txt есть следующий текст: Name Vasya Image 4000 Number 7000 / Name Petya Image 1500 Number 50000 /

29
 Аватар для Wolflind
127 / 107 / 31
Регистрация: 17.03.2016
Сообщений: 445
Записей в блоге: 1
20.07.2018, 13:31
создай объект отдельный с полями нужными либо используй DateSet
а дольше делишь строку и пишиш в нужные столбцы
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
20.07.2018, 15:10  [ТС]
Wolflind, есть класс
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
 public class Table
        {
            public string sec_doc { get; set; }
            public string number { get; set; }
            public string date { get; set; }
            public string summ { get; set; }
            public string schet_pl { get; set; }
            public string pl { get; set; }
            public string inn_pl { get; set; }
            public string kpp_pl { get; set; }
            public string pl1 { get; set; }
            public string pl2 { get; set; }
            public string pl_ras_schet { get; set; }
            public string pl_bank1 { get; set; }
            public string pl_bank2 { get; set; }
            public string pl_bik { get; set; }
            public string pl_kor_schet { get; set; }
            public string pol_schet { get; set; }
            public string date_spis { get; set; }
            public string pol { get; set; }
            public string pol_inn { get; set; }
            public string pol_kpp { get; set; }
            public string pol1 { get; set; }
            public string pol2 { get; set; }
            public string pol3 { get; set; }
            public string pol4 { get; set; }
            public string pol_ras_schet { get; set; }
            public string pol_bank1 { get; set; }
            public string pol_bank2 { get; set; }
            public string pol_bik{ get; set; }
            public string pol_kor_schet { get; set; }
            public string vid_pl { get; set; }
            public string ochered { get; set; }
            public string nazn_pl { get; set; }
        }
как вот через него и выводить, как разделить строку
C#
1
2
3
4
5
 string line;
                while ((line = reader.ReadLine()) != null)
                {
                    MessageBox.Show(line);
                }
пишет каждую строку, но там то нужно не все значение
0
 Аватар для Wolflind
127 / 107 / 31
Регистрация: 17.03.2016
Сообщений: 445
Записей в блоге: 1
20.07.2018, 15:12
А в каком виде в файле это?
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
20.07.2018, 15:17  [ТС]
Wolflind, текстовый файл, скажем
НомерСчета=0099998999
Получаетль=Тест и т.д
0
 Аватар для Wolflind
127 / 107 / 31
Регистрация: 17.03.2016
Сообщений: 445
Записей в блоге: 1
20.07.2018, 15:29
файл должен не так быть заполнен чтоб твой способ сработал а так
НомерСчета=0099998999=Получаетль=Тест=и т.д
НомерСчета=0099998999=Получаетль=Тест=и т.д
НомерСчета=0099998999=Получаетль=Тест=и т.д
НомерСчета=0099998999=Получаетль=Тест=и т.д
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
20.07.2018, 15:30  [ТС]
Wolflind, имели в виду вот так выводить
C#
1
2
3
4
5
6
7
8
9
try
                    {
                        char s = '=';
                        int start = line.IndexOf(s);
                        String substring = line.Substring(start+1);
                        MessageBox.Show(substring);
                    }
                    catch
                    { }
Добавлено через 51 секунду
Wolflind, может вы знаете какой либо способ для моего случая
0
 Аватар для Wolflind
127 / 107 / 31
Регистрация: 17.03.2016
Сообщений: 445
Записей в блоге: 1
20.07.2018, 15:33
разбивай не по /n
а по тому что встречается в каждой строке(грида) ну например НомерСчета
а то что получится снова по /n и значения тогда в ячейках будит
НомерСчета=0099998999
чтоб вытащить значения делеш по = потом смотря от s[0] пишешь s[1] в нужную колонку
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
20.07.2018, 15:54  [ТС]
Wolflind, вот так получилось
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
string[] str1 = myRead.ReadToEnd().Split('=');
                num = str1.Count();
                dataGridView1.RowCount = num + 1;
                for (int i = 0; i < num; i++)
                {
                    {
 
                        str = str1[i].Split('\n');
                        for (int j = 0; j < dataGridView1.ColumnCount; j++)
                        {
                            try
                            {
                                dataGridView1.Rows[i].Cells[j].Value = str[j];
                            }
 
                            catch (Exception ex)
                            {
                                MessageBox.Show(ex.Message);
                            }
                        }
                    }
                }
а как вы говорите по ячейкам

Добавлено через 11 минут
как колонку указать не могу понять
0
 Аватар для Wolflind
127 / 107 / 31
Регистрация: 17.03.2016
Сообщений: 445
Записей в блоге: 1
20.07.2018, 16:27
в ячейках у вал должно быть НомерСчета=0099998999
нужно для каждого токово значения сделать примерно так
C#
1
2
3
4
5
str = str1[i].Split('=');
if(str[0] == "НомерСчета")
    dataGridView1.Rows[i].Cells[1].Value = str[1];
else if(str[0] == "n")
    dataGridView1.Rows[i].Cells[n].Value = str[1];
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
23.07.2018, 10:59  [ТС]
Wolflind, делаю вот так
C#
1
2
3
4
5
6
7
8
9
10
11
12
 string[] str1 = myRead.ReadToEnd().Split('\n');
                num = str1.Count();
                dataGridView1.RowCount = num;
                for (int i = 0; i < num; i++)
                {
                    {
 
                        str = str1[i].Split('=');
                        if (str[0] == "Номер")
                            dataGridView1.Rows[i].Cells[0].Value = str[1];
                    }
                }
он да выводит только то где написано Номер в одном слобце при этом оставляю пустые строки там где нет номера

Добавлено через 6 минут
Wolflind, если с этой строчкой
C#
1
2
else if(str[0] == "n")
    dataGridView1.Rows[i].Cells[n].Value = str[1];
то туда судя по брейкпоинтам даже захода нет

Добавлено через 7 минут
Wolflind, если выставляю ColumCount=10 например то он делает десять одинаковых колонок, то есть надо что если
номер 1 колонка а дальше если не номер то вторая и третья

Добавлено через 4 минуты
Wolflind, то есть нужен цикл на добавление колонок
C#
1
2
3
4
5
6
7
if (str[0] != "Номер")
                        {
                            for (int j = 0; j < dataGridView1.ColumnCount; j++)
                            {
                                dataGridView1.Rows[i].Cells[j].Value = str[1];
                            }
                        }
примерно такой как я понимаю

Добавлено через 23 секунды
только вот условия для цикла не понятны
0
 Аватар для PoPsa85
814 / 561 / 240
Регистрация: 01.07.2018
Сообщений: 1,818
23.07.2018, 11:10
Вы класс создали ? Заполните List<Class>. Потом ObjectListView.SetObjects(List<Class>)
0
 Аватар для Wolflind
127 / 107 / 31
Регистрация: 17.03.2016
Сообщений: 445
Записей в блоге: 1
23.07.2018, 11:12
Цитата Сообщение от menafis Посмотреть сообщение
if (str[0] == "Номер")
dataGridView1.Rows[i].Cells[0].Value = str[1];
Цитата Сообщение от menafis Посмотреть сообщение
то туда судя по брейкпоинтам даже захода нет
я имел ввиду


C#
1
2
3
4
if (str[0] == "Получаетль")
    dataGridView1.Rows[i].Cells[1].Value = str[1];
if (str[0] == "и т.д")
     dataGridView1.Rows[i].Cells[и т.д].Value = str[1];
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
23.07.2018, 11:16  [ТС]
PoPsa85, вот класс
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
 public class Table
        {
            public string sec_doc { get; set; }
            public string number { get; set; }
            public string date { get; set; }
            public string summ { get; set; }
            public string schet_pl { get; set; }
            public string pl { get; set; }
            public string inn_pl { get; set; }
            public string kpp_pl { get; set; }
            public string pl1 { get; set; }
            public string pl2 { get; set; }
            public string pl_ras_schet { get; set; }
            public string pl_bank1 { get; set; }
            public string pl_bank2 { get; set; }
            public string pl_bik { get; set; }
            public string pl_kor_schet { get; set; }
            public string pol_schet { get; set; }
            public string date_spis { get; set; }
            public string pol { get; set; }
            public string pol_inn { get; set; }
            public string pol_kpp { get; set; }
            public string pol1 { get; set; }
            public string pol2 { get; set; }
            public string pol3 { get; set; }
            public string pol4 { get; set; }
            public string pol_ras_schet { get; set; }
            public string pol_bank1 { get; set; }
            public string pol_bank2 { get; set; }
            public string pol_bik{ get; set; }
            public string pol_kor_schet { get; set; }
            public string vid_pl { get; set; }
            public string ochered { get; set; }
            public string nazn_pl { get; set; }
        }
0
 Аватар для PoPsa85
814 / 561 / 240
Регистрация: 01.07.2018
Сообщений: 1,818
23.07.2018, 11:18
menafis, Не знаю. Дайте часть txt и скажите какие колонки вам нужно выводить в таблицу.
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
23.07.2018, 11:22  [ТС]
PoPsa85,
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
using (StreamReader reader = new StreamReader(@"C:\Users\CRIT\Desktop\movements.TXT"))
            {
 
                List<Table> Tables = new List<Table>();
                string line;
                while ((line = reader.ReadLine()) != null)
                {
                    try
                    {
                        char s = '=';
                        int start = line.IndexOf(s);
                        String substring = line.Substring(start + 1);
                        
                    }
                    catch
                    { }
                }
                dataGridView1.DataSource = Tables;
            }
только не могу добавить в датагрид
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
23.07.2018, 11:27  [ТС]
PoPsa85,
Вложения
Тип файла: txt movements.TXT (842 байт, 17 просмотров)
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
23.07.2018, 11:28  [ТС]
PoPsa85, грубо говоря то что до знака равно колонки, то что после содержимое
0
 Аватар для Wolflind
127 / 107 / 31
Регистрация: 17.03.2016
Сообщений: 445
Записей в блоге: 1
23.07.2018, 11:32
зачем 2 тему создавали?
Вывод значение по столбцам

я же писал нужно для начала разделить так

значение 1
СекцияДокумент=Платежное поручение
****
КонецДокумента

значение 2
СекцияДокумент=Платежное поручение
****
КонецДокумента

значение 3
СекцияДокумент=Платежное поручение
****
КонецДокумента

а потом делите еще раз но вытаскиваете значение
Цитата Сообщение от Wolflind Посмотреть сообщение
if (str[0] == "Получаетль")
* * dataGridView1.Rows[i].Cells[1].Value = str[1];
if (str[0] == "и т.д")
* * *dataGridView1.Rows[i].Cells[и т.д].Value = str[1];

вот так
0
 Аватар для PoPsa85
814 / 561 / 240
Регистрация: 01.07.2018
Сообщений: 1,818
23.07.2018, 11:32
menafis, ObjectListView
Подключаете. Собираете проект. Кидаете на форму ObjectListView. Добавляете столбцы. В aspectname столбца имя поля List.
ObjectListView.SetObjects(Tables)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.07.2018, 11:32
Помогаю со студенческими работами здесь

Вывод информации из txt
Здравствуйте, нужно сделать скрипт, который из файла log.txt в котором хранится 20.06.12 19:05|NonStop|36|48|Dj Sandro Escobar Feat...

Вывод информации о папках в txt
Зайти в папку, сохранить все названия файлов в тхт, зайти во все папки которые есть в этой папке, повторить. К примеру в папке &quot;New...

Вывод информации в txt файл
Доброго времени суток. Помогите с выводом информации в текстовый документ.Программа считает время простоя установки в формате чч:мм:cc,...

Вывод информации из txt в мою таблицу
Здравствуйте, я хотел осуществить вывод информации из txt в мою таблицу. Вод код таблицы: &lt;html&gt; &lt;head&gt; &lt;meta...

Вывод информации из *.txt файла построчно
Здравствуйте! Такая проблемма... имеется *.txt файл содержанием Задача: В одну строчку вывести на экран &quot;Иванов Иван...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru