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

Создание приложения «Интерактивный анализ набора данных»

19.06.2019, 17:16. Показов 576. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ошибки при компиляции, помогите создать полноценное приложение
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Drawing;
namespace CarsShowroom
{
public class Car
 {
private int id; // Уникальныйномеравто
private string make; // Маркаавто
private string model; // Модельавто
private Bitmapphoto; // Фотоавто
private stringcountry; // Страна-производительавто
private int year; // Годвыпускаавто
private int power; // Мощностьдвигателя
private double price; // Ценаавто
public Car()
 { }
// id
public int Id
 {
get
 {
return id;
 }
set
 {
 id = value;
 }
 }
// make
public string Make
 {
get
 {
return make;
 }
set
 {
 make = value;
 }
 }
// model
public string Model
 {
get
 {
return model;
 }
set
 {
 model = value;
 }
 }
// country
public string Country
 {
get
 {
return country;
 }
set
 {
 country = value;
 }
 }
 
// power
public int Power
 {
get
 {
return power;
 }
set
 {
 power = value;
 }
 }
// year
public int Year
 {
get
 {
return year;
 }
set
 {
 year = value;
 }
 }
// price
public double Price
 {
get
 {
return price;
 }
set
 {
 price = value;
 }
 }
// photo
public Bitmap Photo
 {
get
 {
return photo;
 }
set
 {
 photo = value;
 }
 }
 }
}
Файл Form2.cs

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
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
usingMicrosoft.VisualBasic;
using System;
usingSystem.Collections.Generic;
usingSystem.ComponentModel;
usingSystem.Data;
usingSystem.Drawing;
usingSystem.Linq;
usingSystem.Text;
usingSystem.Threading.Tasks;
usingSystem.Windows.Forms;
using System.IO;
usingSystem.Xml.Serialization;
namespaceCarsShowroom
{
publicpartialclassForm2 :Form
 {
privateXmlSerializerxmls = newXmlSerializer(typeof(List<Car>));
privatestringmakeToFind = "";
public Form2()
 {
InitializeComponent();
carBindingSource.DataSource = newList<Car>();
 id2.Tag = 0;
 year2.Tag = 1;
 price2.Tag = 2;
 }
privatevoid dataGridView1_CellValidating(object sender, DataGridViewCellValidatingEventArgs e)
 {
if (dataGridView1.Rows[e.RowIndex].IsNewRow)
return;
string err = "", s = e.FormattedValue.ToString();
inti; double d;
switch (e.ColumnIndex)
 {
// id
case 0:
// make
case 1:
if (s == "")
err = "Поле "Марка" не должно быть пустым";
break;
// model
case 2:
if (s == "")
err = "Поле "Модель" не должно быть пустым";
break;
// country
case 3:
if (s == "")
err = "Поле "Производитель" не должно быть пустым";
break;
// power
case 4:
if(!int.TryParse(s, outi))
err = "Строку нельзя преобразовать в число";
elseif (i < 0)
err = "Отрицательные числа не допускаются";
break;
// year 
case 5:
if(!int.TryParse(s, outi))
err = "Строку нельзя преобразовать в число";
elseif (i < 0)
err = "Отрицательные числа не допускаются";
break;
// price
case 6:
if(!double.TryParse(s, out d))
err = "Строку нельзя преобразовать в число";
elseif (d < 0)
err = "Отрицательные числа не допускаются";
break;
 }
e.Cancel = err != "";
 dataGridView1.Rows[e.RowIndex].ErrorText = err;
 }
privatevoid dataGridView1_RowValidating(object sender, DataGridViewCellCancelEventArgs e)
 {
if (dataGridView1.Rows[e.RowIndex].IsNewRow)
return;
string err = "";
if (dataGridView1[1, e.RowIndex].Value == null)
err = "Поле "Марка" должно быть непустым";
e.Cancel = err != "";
 dataGridView1.Rows[e.RowIndex].ErrorText = err;
 }
privatevoidSaveData(string name)
 {
if (name == "" || dataGridView1.RowCount == 1)
return;
if (dataGridView1.CurrentRow.IsNewRow)
 dataGridView1.CurrentCell =
 dataGridView1[0, dataGridView1.RowCount - 2];
StreamWritersw = newStreamWriter(name, false, Encoding.Default);
xmls.Serialize(sw, carBindingSource.DataSource);
sw.Close();
 }
privatevoid new1_Click(object sender, EventArgs e)
 {
SaveData(saveFileDialog1.FileName);
carBindingSource.DataSource = newList<Car>();
 dataGridView1.CurrentCell = dataGridView1[0, 0];
 saveFileDialog1.FileName = "";
 Text = "CarShop";
foreach (DataGridViewRow row in dataGridView1.Rows)
 {
row.Height = 60;
 }
 }
privatevoid open1_Click(object sender, EventArgs e)
 {
 openFileDialog1.FileName = "";
if (openFileDialog1.ShowDialog() == DialogResult.OK)
 {
SaveData(saveFileDialog1.FileName);
string s = openFileDialog1.FileName;
StreamReadersr = newStreamReader(s, Encoding.Default);
carBindingSource.SuspendBinding();
carBindingSource.DataSource = xmls.Deserialize(sr);
carBindingSource.ResumeBinding();
sr.Close();
 saveFileDialog1.FileName = s;
 Text = "CarShop - " + Path.GetFileNameWithoutExtension(s);
int n = dataGridView1.RowCount;
for (inti = 0; i< n; i++)
 {
 dataGridView1.Rows[i].Cells[1].Value = newBitmap(dataGridView1.Rows[i].Cells[7].Value + "");
 dataGridView1.Rows[i].Height = newBitmap(dataGridView1.Rows[i].Cells[7].Value + "").Height;
 }
 }
 }
privatevoid save1_Click(object sender, EventArgs e)
 {
if (saveFileDialog1.ShowDialog() == DialogResult.OK)
{
string h = saveFileDialog1.FileName;
SaveData(h);
 Text = "Car - " + Path.GetFileNameWithoutExtension(h);
}
 }
privatevoid Form2_FormClosing(object sender, FormClosingEventArgs e)
 {
SaveData(saveFileDialog1.FileName);
 }
privatevoid file1_DropDownOpening(object sender, EventArgs e)
 {
 save1.Enabled = dataGridView1.RowCount > 1;
 }
privatevoid dataGridView1_CurrentCellDirtyStateChanged(object sender, EventArgs e)
 {
 menuStrip1.Enabled = !dataGridView1.IsCurrentCellDirty;
int row = dataGridView1.CurrentRow.Index;
if(!dataGridView1.IsCurrentCellDirty&&
 (int)dataGridView1["Id1", row].Value == 0)
 {
intmaxId = 0;
for (inti = 0; i< row; i++)
 {
int v = (int)dataGridView1["Id1", i].Value;
if (maxId< v)
maxId = v;
 }
 dataGridView1["Id1", row].Value = maxId + 1;
 }
 }
privateintCompareById(Car a, Car b)
 {
returna.Id - b.Id;
 }
privateintCompareByYear(Car a, Car b)
 {
returna.Year.CompareTo(b.Year);
 }
privateintCompareByPrice(Car a, Car b)
 {
returna.Price.CompareTo(b.Price);
 }
privatevoid dataGridView1_RowEnter(object sender, DataGridViewCellEventArgs e)
 {
 find1.Enabled = bindingNavigatorDeleteItem.Enabled= !dataGridView1.Rows[e.RowIndex].IsNewRow;
 }
privatevoid year2_Click(object sender, EventArgs e)
 {
if (dataGridView1.RowCount == 1)
return;
 dataGridView1.CurrentCell = dataGridView1[0, 0];
Comparison<Car> comp = CompareByYear;
switch ((int)(sender asToolStripMenuItem).Tag)
 {
case 0:
 comp = CompareById;
break;
case 1:
 comp = CompareByYear;
break;
case 2:
 comp = CompareByPrice;
break;
 }
 (carBindingSource.DataSourceasList<Car>).Sort(comp);
carBindingSource.ResetBindings(false);
 }
privatevoid find1_Click(object sender, EventArgs e)
{
makeToFind = Interaction.InputBox("Введите начальную часть марки авто для поиска:",
"Поиск по марке авто", makeToFind, -1, -1).Trim();
if (makeToFind == "")
return;
intind = (carBindingSource.DataSourceas
List<Car>).FindIndex(dataGridView1.CurrentRow.Index, delegate (Car a)
 {
returna.Make.StartsWith(makeToFind,
StringComparison.OrdinalIgnoreCase);
 });
if (ind != -1)
 dataGridView1.CurrentCell = dataGridView1[1, ind];
else
MessageBox.Show("Марка авто не найдена", "Поиск по марке авто");
 }
privatevoid button1_Click_1(object sender, EventArgs e)
 {
OpenFileDialog d = newOpenFileDialog();
if (d.ShowDialog() == System.Windows.Forms.DialogResult.Cancel)
return;
Imageimg = Image.FromFile(d.FileName);
dataGridView1.CurrentCell.Value = img;
 }
 }
}
Файл Form1.cs

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
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 CarsShowroom
{
publicpartialclassForm1 : Form
 {
privateForm2 form2 = newForm2();
public Form1()
 {
 InitializeComponent();
 }
privatevoid button1_Click(object sender, EventArgs e)
 {
 form2.Owner = this;
 form2.ShowDialog();
this.Close();
 }
privatevoid button2_Click(object sender, EventArgs e)
{
Application.Exit();
 }
 }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.06.2019, 17:16
Ответы с готовыми решениями:

Ищу информацию: интерактивный ввод данных, создание матриц данных
Помогите найти теоретическую информацию по следующим вопросам. Интерактивный ввод данных (блок HELP LETSA). Создание матриц данных...

Аномальные значения. Анализ набора данных
Добрый день. Уважаемые знатоки, помогите разобраться. У меня есть времена (в часах) решения какого-то заданий (в моем случае заявки...

Создание набора файлов проекта для запуска приложения
Доброго дня! Использую для одного из своих проектов набор утилит srecord, на локальной машине все прекрасно работает, устанавливается...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.06.2019, 17:16
Помогаю со студенческими работами здесь

Создание набора данных .xsd на основе сохраненного дампа базы данных MS SQL
Привет всем! У меня есть текстовый файл - дамп (если правильно выражаюсь) базы данных с расширением .sql такого вида: USE GO ...

Разработка приложения по поддержке набора данных на основе двухстороннего связного списка, хранимого в файле
Помогите сделать запись в файл files.mail.ru/CFA6D93E1F894D3686927D629CFFF2A7 вот курсач, все сделано кроме записи в файл ...

Создание приложения (проблема с базой данных)
Привет-привет. Решил НАЧАТЬ писать приложение на Java. И, как пример, взял ролики с канала &quot;Гоша Дударь&quot;. Дак вот... Всё шло...

Создание приложения для базы данных
Доброго времени суток. Моя задача - сделать приложение для работы с базой данных. То есть формы в которых можно отображать, добавлять и...

Создание приложения для работы с базой данных (firebird)
Есть база, подключенная к visual studio, а что с ней делать дальше не ясно. Раньше с этим не сталкивался, дайте пожалуйста ссылки, где...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru