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

Чтение и запись данный в файл GRID

24.04.2019, 16:57. Показов 1382. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно не используя SQL сделать БД , а именно организовать
-Добавление нового пользователя в GRID
-Удаление
-Обновление
-Сохранение в файл данных из GRID-a
-Открытие этого файла

Я сделал ввод и удаление когда я пытаюсь открыть сохранный файл , выдает ошибку "Индекс находился вне границ массива"
Где ошибка и как реализовать все это правильно ,заранее спасибо.
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
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;
using System.IO;
 
namespace _4Lab
{
    public partial class Form1 : Form
    {
        
        public Form1()
        {
            InitializeComponent();
            
        }
 
        private void выходToolStripMenuItem_Click(object sender, EventArgs e)
        {
            Close();
        }
 
        private void button3_Click(object sender, EventArgs e)
        {
            int id = dataGridView1.SelectedCells[0].RowIndex;
            dataGridView1.Rows.RemoveAt(id);
        }
 
        private void открытьToolStripMenuItem_Click(object sender, EventArgs e)
        {
            Stream mystr = null;
            if (openFileDialog1.ShowDialog()==DialogResult.OK)
            {
                if ((mystr = openFileDialog1.OpenFile())!=null)
                {
                    StreamReader myread = new StreamReader(mystr);
                    string[] str;
                    int num = 0;
                    try
                    {
                        string[] strq = myread.ReadToEnd().Split('\n');
                        num = strq.Count();
                        dataGridView1.RowCount = num;
                        for(int i =0; i<num-1;i++)
                        {
                            str = strq[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);
                    }
                    finally
                    {
                        myread.Close();
                    }
                }
            }
            
        }
 
        private void сохранитьToolStripMenuItem_Click(object sender, EventArgs e)
        {
            Stream mystream ;
            if (saveFileDialog1.ShowDialog()==DialogResult.OK)
            {
                if ((mystream=saveFileDialog1.OpenFile())!=null)
                {
                    StreamWriter myWriter = new StreamWriter(mystream);
                    try
                    {
                        for(int i = 0; i<dataGridView1.RowCount-1;i++)
                        {
                            for(int j = 0; j < dataGridView1.ColumnCount; j++)
                            {
                                myWriter.Write(dataGridView1.Rows[i].Cells[j].Value.ToString() + ' ');
                            }
                            
                        }
                        myWriter.WriteLine();
                    }
                    catch (Exception ex)
                    {
 
                        MessageBox.Show(ex.Message);
                    }
                }
            }
        }
 
        private void button4_Click(object sender, EventArgs e)
        {
            string Index = textBox1.Text;
            string Name = textBox2.Text;
            string Period = textBox3.Text;
            string PriceFirst = textBox4.Text;
            string FullName = textBox5.Text;
            string Adress = textBox6.Text;
            string FullPrice = textBox7.Text;
            string Number = textBox8.Text;
            dataGridView1.Rows.Add(Index,Name,Period,PriceFirst,FullName,Adress,FullPrice,Number);
        }
    }
}
Миниатюры
Чтение и запись данный в файл GRID  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.04.2019, 16:57
Ответы с готовыми решениями:

Быстрое чтение типизированного файла и запись в grid
Господа, вот такой вопрос: есть типизированный файл с большим количеством записей (допустим, до 1млн), его нужно максимально быстро...

Открыть текстовый файл в необходимом режиме (на чтение, на чтение и запись, на добавление)
Открыть текстовый файл в необходимом режиме (на чтение, на чтение и запись, на добавление). (В файле должно быть не менее 30 строк)....

Запись данный в файл
.586 .model flat, stdcall GENERIC_READ equ 80000000h GENERIC_WRITE equ 40000000h CREATE_ALWAYS equ 2 includelib...

1
172 / 118 / 57
Регистрация: 08.01.2013
Сообщений: 664
24.04.2019, 20:14
Цитата Сообщение от Halacky Посмотреть сообщение
Я сделал ввод и удаление когда я пытаюсь открыть сохранный файл , выдает ошибку "Индекс находился вне границ массива"
Правильно и делает, вы же не очищаете datagreidview, перед открытием файла. Да и при этом в коде Вы редактируете записи, а не добавляете:
C#
1
dataGridView1.Rows[i].Cells[j].Value = str[j];
Добавлено через 2 минуты
Добавление записи в dgv:
C#
1
2
dataGridView.Columns.Add(new DataGridViewTextBoxColumn { DataPropertyName = "Name", HeaderText = "Имя" });
// ошибочка, это добавление колонки в dgv
Добавлено через 1 минуту
Посмотрите эту и эту тему, и Вы поймете как делать.

Добавлено через 7 минут
Добавление записи в DGV:
C#
1
dataGridView1.Rows.Add(1, "Гном"); // Тут 2 колонки
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.04.2019, 20:14
Помогаю со студенческими работами здесь

Чтение файла, чтение названия папки где находится файл, запись данных на PHP
Допустим у нас есть структура с папками типа Large -&gt; Vehicles -&gt; Firetruck_0 В этой папке лежит файл формата .dat Что нужно сделать? ...

Ввод с клавиатуры и запись в файл, чтение из файла и запись в массив, вывод из массива на экран
1.Ввод с клавиатуры и запись в файл, чтение из файла и запись в массив, вывод из массива на экран 2.Ввод с клавиатуры и запись в массив,...

Запись в файл, чтение из файла, сохранени в файл, не работают эти функции
Здравствуйте. Не работает методы: Save() — сохранение фигуры (объекта) в файл, Load() — считывание фигуры (объекта) из файла. ...

Открытие и чтение файла, запись в файл, помещение результата в файл
Eсть алгоритм решения задачи. Не знаю только каким способом открыть файлы и как в них что-либо записывать (для файлов f1 и f2) и помещать...

Написать функцию, которая считывает данный файл и перезаписывает данный файл
Задания: Есть файл, в котором записаны числа массива написать функцию, которая считывает данный файл и перезаписывает данный файл таким...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru