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

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

13.07.2017, 16:53. Показов 1476. Ответов 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
18282 / 14205 / 5368
Регистрация: 17.03.2014
Сообщений: 28,884
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru