Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
9 / 9 / 4
Регистрация: 23.12.2015
Сообщений: 730

Как сделать чтобы данные сохранённые при отладке в таблице отображались после сборки в *.exe файле?

13.07.2017, 16:53. Показов 1515. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Имеется две формы: главная, подчинённая.

Сценарий
1. Запускаю отладку;

2. Создаю таблицу `public DataTable dt_1`;
3. Заполняю таблицу через `dataGridView1`;
4. Сохраняю таблицу в `Settings.settings` в переменную `public global::System.Data.DataTable sett_frm_1_dt_1`;

5. Останавливаю отладку;

6. Выполняю сборку проекта;
7. Запускаю файл `rsh.exe` (c:\...\rsh\bin\Debug\);
В результате переменная `public global::System.Data.DataTable sett_frm_1_dt_1` пуста.

ГЛАВНАЯ ФОРМА
Кликните здесь для просмотра всего текста

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
public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        } // Form1()
 
 
        // ФОРМЫ
        Form2 frm_2; // Form2
        
        public DataTable dt_1;
        
 
        private void button1_Click(object sender, EventArgs e)
        {
            // Form2
            frm_2 = new Form2();
            frm_2.Owner = this;
 
            frm_2.Show();/* или  F2.ShowDialog();*/
        }
 
    }


ПОДЧИНЁННАЯ
Кликните здесь для просмотра всего текста
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
124
125
126
127
128
129
130
131
public partial class Form2 : Form
    {
        public Form2()
        {
            InitializeComponent();
        } // public Form2()
 
        Form1 frm_1;
 
        private void Form2_Load(object sender, EventArgs e)
        {
            frm_1 = this.Owner as Form1; 
 
            fnk_crt_dt_1();
        }
 
        private void Form2_Show(object sender, EventArgs e)
        {
 
            #region *** СОБЫТИЯ. f_prt_1.dt_030_html ***
            // Подписываемся на событие вставки новой строки.//
            frm_1.dt_1.TableNewRow += DataTableNewRow; // 
            
            // СОБЫТИЕ. Происходит после успешного изменения DataRow
            frm_1.dt_1.RowChanged += new DataRowChangeEventHandler(Row_Changed); // 
            
            // СОБЫТИЕ. Происходит после удаления строки в таблице.
            frm_1.dt_1.RowDeleted += new DataRowChangeEventHandler(Row_Deleted); // 
            #endregion *** СОБЫТИЯ. f_prt_1.dt_030_html ***. КОНЕЦ ХХХ           
 
            // извлечь таблицу из Settings
            // fnk_frm_1_dt_1_fr_set();
 
        } // Form2_Show
 
 
        // СОБЫТИЕ. ПРИСВОИТЬ ID // 
        private void DataTableNewRow(object sender, DataTableNewRowEventArgs dataTableNewRowEventArgs)
        {
            try
            {
                int max = (int)frm_1.dt_1.Compute("Max(ID)", "");
                dataTableNewRowEventArgs.Row["ID"] = max + 1; // dataTableNewRowEventArgs - вызывает событие TableNewRow.
            }
            catch
            {
 
            }
        }
 
        // СОБЫТИЕ. Происходит после успешного изменения DataRow
        private void Row_Changed(object sender, DataRowChangeEventArgs e) //          
        {
            Properties.Settings.Default.sett_frm_1_dt_1 = frm_1.dt_1;
 
            Properties.Settings.Default.Save();
        }
 
        // СОБЫТИЕ. Происходит после удаления строки в таблице.        
        private void Row_Deleted(object sender, DataRowChangeEventArgs e)
        {   
            Properties.Settings.Default.sett_frm_1_dt_1 = frm_1.dt_1;
            Properties.Settings.Default.Save();
        }
 
 
        // *** *** *** ***
        // ФУНКЦИИ
        // *** *** *** ***
 
        // создаём таблицу
        public void fnk_crt_dt_1()
        {
            frm_1.dt_1 = new DataTable();
 
            // BS_029_html = new BindingSource();
 
            frm_1.dt_1.TableName = "frm_1_dt_1_Name";
 
            // ДОБАВЛЕНИЕ ПОЛЕЙ            
            frm_1.dt_1.Columns.Add("ID", typeof(Int32));
            frm_1.dt_1.Columns.Add("pl_1", typeof(String)); // Имя html сценария
            frm_1.dt_1.Columns.Add("pl_2", typeof(String));
            frm_1.dt_1.Columns.Add("pl_3", typeof(String));            
 
            // добавляем первый 'ID' = 1
            DataRow newRow = frm_1.dt_1.NewRow();
            newRow["ID"] = 1;
            frm_1.dt_1.Rows.Add(newRow);
 
            dataGridView1.DataSource = frm_1.dt_1;
        }
 
        public void fnk_frm_1_dt_1_in_set() // сохранить
        {
            Properties.Settings.Default.sett_frm_1_dt_1 = frm_1.dt_1;
            Properties.Settings.Default.Save();
 
        }
 
        public void fnk_frm_1_dt_1_fr_set() // извлечь
        {
            frm_1.dt_1 = Properties.Settings.Default.sett_frm_1_dt_1;            
            dataGridView1.DataSource = frm_1.dt_1;
 
        }
 
 
        // *** *** *** ***
        // КНОПКИ
        // *** *** *** ***
 
            // создаём таблицу
        private void button1_Click(object sender, EventArgs e)
        {
            fnk_crt_dt_1();
        }
 
        // сохранить таблицу
        private void button2_Click(object sender, EventArgs e)
        {
            fnk_frm_1_dt_1_in_set();
        }
 
        // извлечь таблицу
        private void button3_Click(object sender, EventArgs e)
        {
            fnk_frm_1_dt_1_fr_set();
        }
 
    } // Form2 : Form



ВОПРОС
1. Как сделать чтобы данные сохранённые при отладке в переменную`public global::System.Data.DataTable sett_frm_1_dt_1` после сборки отображались в `rsh.exe` файле?
2. Также как сделать чтобы данные отображались, если файл `rsh.exe` перемещён в другую папку?
Миниатюры
Как сделать чтобы данные сохранённые при отладке в таблице отображались после сборки в *.exe файле?  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.07.2017, 16:53
Ответы с готовыми решениями:

Сделать, чтобы при нажатии на узел treeView в dataGridView отображались данные из бд
Здравствуйте я дубок и хочу узнать как сделать чтобы при нажатии на узел treeView в dataGridView отображались данные из бд using System; ...

В таблице последнее значение 2 столбцов по условию должно быть равно 0, как сделать так, чтобы отображались нули
При построении таблицы последнее значение 2 столбцов по условию должно быть равно 0, как сделать так, чтобы отображались нули и из-за чего...

Как сделать так чтобы при выборе значения в списке менялись данные в таблице ?
Есть проблема: имеется список выбора select и таблица Как сделать так чтобы при выборе значения в списке менялись данные в таблице,...

4
 Аватар для kesean
292 / 291 / 108
Регистрация: 04.09.2010
Сообщений: 638
13.07.2017, 19:43
Лучший ответ Сообщение было отмечено zakaz_77 как решение

Решение

zakaz_77, сохраняй свой DataTable на диске
C#
1
dt_1.WriteXml(filename);
При запуске считывай данные
C#
1
dt_1.ReadXml(filename);
1
9 / 9 / 4
Регистрация: 23.12.2015
Сообщений: 730
14.07.2017, 08:49  [ТС]
kesean,
А если настройки нужно сохранить для:
- таблица 1;
- таблица 2;
- таблица ...;
- таблица n;

- textBox1;
- textBox2;
- textBox...;
- textBoxN;
то для каждого элемента нужно делать файл `*.xml`?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18307 / 14231 / 5368
Регистрация: 17.03.2014
Сообщений: 28,904
Записей в блоге: 1
14.07.2017, 14:04
Лучший ответ Сообщение было отмечено zakaz_77 как решение

Решение

zakaz_77, таблицы можно объеденить в DataSet который можно загружать и сохранять целиком теми же методами ReadXml, WriteXml.

По начальному вопросу - у тебя есть код сохранения переменной в настройку, но нет кода чтения из настроек.
1
9 / 9 / 4
Регистрация: 23.12.2015
Сообщений: 730
14.07.2017, 14:57  [ТС]
Цитата Сообщение от OwenGlendower Посмотреть сообщение
таблицы можно объеденить в DataSet который можно загружать и сохранять целиком теми же методами ReadXml, WriteXml.
А
- textBox1;
- textBox2;
- textBox...;
- textBoxN;
как-то в один файл объеденить можно?
или другим способом....


Цитата Сообщение от OwenGlendower Посмотреть сообщение
По начальному вопросу - у тебя есть код сохранения переменной в настройку, но нет кода чтения из настроек.
вроде есть... или я, что-то не так понимаю..
Дублирую
C#
1
2
3
4
5
6
 public void fnk_frm_1_dt_1_fr_set() // извлечь
        {
            frm_1.dt_1 = Properties.Settings.Default.sett_frm_1_dt_1;            
            dataGridView1.DataSource = frm_1.dt_1;
 
        }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.07.2017, 14:57
Помогаю со студенческими работами здесь

Как сделать, чтобы элементы в шапке отображались одинаково при любых масштабах/разрешениях?
Доброго времени суток! Сразу оговорюсь, в веб-строительстве я не новичок, но поскольку веб-технологии шагнули далеко вперед, то я по ряду...

Подскажите как сделать чтобы при введении пароля отображались звёздачки а не сам пароль
Подскажите как сделать чтобы при введении пароля отображались звёздачки а не сам пароль <form method='post' action='cont_1.asp'> ...

Как сделать чтобы данные не повторялись в таблице в SQL
Как сделать чтобы данные не повторялись в таблице в SQL Помогите(

Как мне сделать, чтобы при нажатии на блок 2 в 1 таблице, в нижней таблице высвечивалась информация по этому блоку
Программа на С#

Как сделать чтобы данные сохранились в текстовом файле
У меня есть форма ,в которой допустим есть 2 текстбокса (логин и пароль), и кнопка ок. Пользователь вводит данные в текстбокс и нажимает...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru