From 336c947c072ed7d2d681f230de8933dc88f35430 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=96=D0=B5=D0=BB=D0=BE=D0=BD=D0=BA=D0=B8=D0=BD=20=D0=94?= =?UTF-8?q?=D0=B5=D0=BD=D0=B8=D1=81?= Date: Thu, 23 Jan 2025 23:41:57 +0700 Subject: [PATCH] =?UTF-8?q?=D0=93=D0=BE=D1=82=D0=BE=D0=B2=D0=BE=20=D0=BD?= =?UTF-8?q?=D0=B0=20=D0=BF=D1=80=D0=BE=D0=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- NoDuplicate/Form1.Designer.cs | 127 ++++++++++++++++++++- NoDuplicate/Form1.cs | 199 +++++++++++++++++++++++++++++++++ NoDuplicate/Form1.resx | 171 ++++++++++++++++++++++++++++ NoDuplicate/NoDuplicate.csproj | 3 + 4 files changed, 497 insertions(+), 3 deletions(-) create mode 100644 NoDuplicate/Form1.resx diff --git a/NoDuplicate/Form1.Designer.cs b/NoDuplicate/Form1.Designer.cs index 6548878..87ae82e 100644 --- a/NoDuplicate/Form1.Designer.cs +++ b/NoDuplicate/Form1.Designer.cs @@ -28,13 +28,134 @@ /// private void InitializeComponent() { - this.components = new System.ComponentModel.Container(); + System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(Form1)); + this.dataGridView1 = new System.Windows.Forms.DataGridView(); + this.btnRemoveDuplicates = new System.Windows.Forms.Button(); + this.menuStrip1 = new System.Windows.Forms.MenuStrip(); + this.файлToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); + this.импортToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); + this.экспортToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); + this.помощьToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); + this.label1 = new System.Windows.Forms.Label(); + this.lblStatus = new System.Windows.Forms.Label(); + ((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).BeginInit(); + this.menuStrip1.SuspendLayout(); + this.SuspendLayout(); + // + // dataGridView1 + // + this.dataGridView1.AllowUserToAddRows = false; + this.dataGridView1.AllowUserToDeleteRows = false; + this.dataGridView1.AutoSizeColumnsMode = System.Windows.Forms.DataGridViewAutoSizeColumnsMode.Fill; + this.dataGridView1.ColumnHeadersHeightSizeMode = System.Windows.Forms.DataGridViewColumnHeadersHeightSizeMode.AutoSize; + this.dataGridView1.Location = new System.Drawing.Point(12, 36); + this.dataGridView1.Name = "dataGridView1"; + this.dataGridView1.ReadOnly = true; + this.dataGridView1.Size = new System.Drawing.Size(464, 389); + this.dataGridView1.TabIndex = 0; + // + // btnRemoveDuplicates + // + this.btnRemoveDuplicates.Location = new System.Drawing.Point(12, 431); + this.btnRemoveDuplicates.Name = "btnRemoveDuplicates"; + this.btnRemoveDuplicates.Size = new System.Drawing.Size(126, 23); + this.btnRemoveDuplicates.TabIndex = 1; + this.btnRemoveDuplicates.Text = "Удалить дубликаты"; + this.btnRemoveDuplicates.UseVisualStyleBackColor = true; + this.btnRemoveDuplicates.Click += new System.EventHandler(this.btnRemoveDuplicates_Click); + // + // menuStrip1 + // + this.menuStrip1.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { + this.файлToolStripMenuItem, + this.помощьToolStripMenuItem}); + this.menuStrip1.Location = new System.Drawing.Point(0, 0); + this.menuStrip1.Name = "menuStrip1"; + this.menuStrip1.Size = new System.Drawing.Size(488, 24); + this.menuStrip1.TabIndex = 2; + this.menuStrip1.Text = "menuStrip1"; + // + // файлToolStripMenuItem + // + this.файлToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { + this.импортToolStripMenuItem, + this.экспортToolStripMenuItem}); + this.файлToolStripMenuItem.Name = "файлToolStripMenuItem"; + this.файлToolStripMenuItem.Size = new System.Drawing.Size(48, 20); + this.файлToolStripMenuItem.Text = "Файл"; + // + // импортToolStripMenuItem + // + this.импортToolStripMenuItem.Name = "импортToolStripMenuItem"; + this.импортToolStripMenuItem.Size = new System.Drawing.Size(119, 22); + this.импортToolStripMenuItem.Text = "Импорт"; + this.импортToolStripMenuItem.Click += new System.EventHandler(this.импортToolStripMenuItem_Click); + // + // экспортToolStripMenuItem + // + this.экспортToolStripMenuItem.Name = "экспортToolStripMenuItem"; + this.экспортToolStripMenuItem.Size = new System.Drawing.Size(119, 22); + this.экспортToolStripMenuItem.Text = "Экспорт"; + this.экспортToolStripMenuItem.Click += new System.EventHandler(this.экспортToolStripMenuItem_Click); + // + // помощьToolStripMenuItem + // + this.помощьToolStripMenuItem.Name = "помощьToolStripMenuItem"; + this.помощьToolStripMenuItem.Size = new System.Drawing.Size(68, 20); + this.помощьToolStripMenuItem.Text = "Помощь"; + this.помощьToolStripMenuItem.Click += new System.EventHandler(this.помощьToolStripMenuItem_Click); + // + // label1 + // + this.label1.AutoSize = true; + this.label1.Location = new System.Drawing.Point(159, 436); + this.label1.Name = "label1"; + this.label1.Size = new System.Drawing.Size(44, 13); + this.label1.TabIndex = 3; + this.label1.Text = "Статус:"; + // + // lblStatus + // + this.lblStatus.AutoSize = true; + this.lblStatus.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, ((byte)(204))); + this.lblStatus.Location = new System.Drawing.Point(209, 436); + this.lblStatus.Name = "lblStatus"; + this.lblStatus.Size = new System.Drawing.Size(0, 13); + this.lblStatus.TabIndex = 4; + // + // Form1 + // + this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; - this.ClientSize = new System.Drawing.Size(800, 450); - this.Text = "Form1"; + this.ClientSize = new System.Drawing.Size(488, 462); + this.Controls.Add(this.lblStatus); + this.Controls.Add(this.label1); + this.Controls.Add(this.btnRemoveDuplicates); + this.Controls.Add(this.dataGridView1); + this.Controls.Add(this.menuStrip1); + this.Icon = ((System.Drawing.Icon)(resources.GetObject("$this.Icon"))); + this.MainMenuStrip = this.menuStrip1; + this.Name = "Form1"; + this.Text = "NoDuplicate"; + ((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).EndInit(); + this.menuStrip1.ResumeLayout(false); + this.menuStrip1.PerformLayout(); + this.ResumeLayout(false); + this.PerformLayout(); + } #endregion + + private System.Windows.Forms.DataGridView dataGridView1; + private System.Windows.Forms.Button btnRemoveDuplicates; + private System.Windows.Forms.MenuStrip menuStrip1; + private System.Windows.Forms.ToolStripMenuItem файлToolStripMenuItem; + private System.Windows.Forms.ToolStripMenuItem импортToolStripMenuItem; + private System.Windows.Forms.ToolStripMenuItem экспортToolStripMenuItem; + private System.Windows.Forms.ToolStripMenuItem помощьToolStripMenuItem; + private System.Windows.Forms.Label label1; + private System.Windows.Forms.Label lblStatus; } } diff --git a/NoDuplicate/Form1.cs b/NoDuplicate/Form1.cs index ac33d77..8a52137 100644 --- a/NoDuplicate/Form1.cs +++ b/NoDuplicate/Form1.cs @@ -3,18 +3,217 @@ using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; +using System.IO; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; +using OfficeOpenXml; +using OfficeOpenXml; + namespace NoDuplicate { public partial class Form1 : Form { + + private DataTable emailTable; // Таблица для хранения данных + public Form1() { InitializeComponent(); } + + private void импортToolStripMenuItem_Click(object sender, EventArgs e) + { + OpenFileDialog openFileDialog = new OpenFileDialog + { + Filter = "Excel Files|*.xlsx", + Title = "Выберите файл с email-адресами" + }; + + if (openFileDialog.ShowDialog() == DialogResult.OK) + { + string filePath = openFileDialog.FileName; + + try + { + // Указываем лицензионный контекст для EPPlus + OfficeOpenXml.ExcelPackage.LicenseContext = OfficeOpenXml.LicenseContext.NonCommercial; + + using (var package = new ExcelPackage(new FileInfo(filePath))) + { + var worksheet = package.Workbook.Worksheets[0]; // Первый лист + int rows = worksheet.Dimension.Rows; // Количество строк + + emailTable = new DataTable(); + emailTable.Columns.Add("Email", typeof(string)); + + for (int row = 1; row <= rows; row++) + { + string email = worksheet.Cells[row, 1].Text; + if (!string.IsNullOrEmpty(email)) + { + emailTable.Rows.Add(email); + } + } + + dataGridView1.DataSource = emailTable; + //MessageBox.Show("Данные успешно загружены!", "Импорт"); + } + } + catch (Exception ex) + { + MessageBox.Show($"Ошибка при импорте файла: {ex.Message}", "Ошибка"); + } + } + } + + private List removedEmails = new List(); // Список для хранения удалённых адресов + private string reportsDirectory = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments), "MyAppReports"); // Путь к папке для отчётов + + private void SaveReport() + { + try + { + // Проверяем и создаём директорию, если её нет + if (!Directory.Exists(reportsDirectory)) + { + Directory.CreateDirectory(reportsDirectory); + } + + // Проверяем, есть ли удалённые адреса + if (removedEmails.Count == 0) + { + MessageBox.Show("Нет удалённых адресов для отчёта.", "Информация"); + return; + } + + // Формируем имя файла отчёта + string reportFileName = $"RemovedEmailsReport_{DateTime.Now:yyyyMMdd_HHmmss}.txt"; + string reportPath = Path.Combine(reportsDirectory, reportFileName); + + // Записываем данные в файл + using (StreamWriter writer = new StreamWriter(reportPath)) + { + writer.WriteLine($"Отчёт о удалённых адресах ({DateTime.Now}):"); + writer.WriteLine($"Всего удалено: {removedEmails.Count}"); + writer.WriteLine("Список удалённых адресов:"); + foreach (var email in removedEmails) + { + writer.WriteLine(email); + } + } + + //MessageBox.Show($"Отчёт сохранён в папке: {reportsDirectory}", "Успех"); + } + catch (Exception ex) + { + MessageBox.Show($"Ошибка при сохранении отчёта: {ex.Message}", "Ошибка"); + } + } + + + private void btnRemoveDuplicates_Click(object sender, EventArgs e) + { + if (emailTable == null || emailTable.Rows.Count == 0) + { + lblStatus.Text = "Таблица пуста или не загружена."; + lblStatus.ForeColor = Color.Red; // Красный цвет для ошибки + return; + } + + try + { + var allEmails = emailTable.AsEnumerable() + .Select(row => row.Field("Email").Trim()) + .ToList(); + + var distinctEmails = allEmails.Distinct(StringComparer.OrdinalIgnoreCase).ToList(); + + removedEmails = allEmails + .GroupBy(email => email, StringComparer.OrdinalIgnoreCase) + .Where(group => group.Count() > 1) + .SelectMany(group => group.Skip(1)) + .ToList(); + + emailTable.Rows.Clear(); + foreach (var email in distinctEmails) + { + emailTable.Rows.Add(email); + } + + dataGridView1.DataSource = emailTable; + + SaveReport(); + + // Обновляем сообщение на форме + lblStatus.Text = $"Удаление завершено! Удалено {removedEmails.Count} адрес(ов)."; + lblStatus.ForeColor = Color.Green; // Зелёный цвет для успеха + } + catch (Exception ex) + { + lblStatus.Text = $"Ошибка: {ex.Message}"; + lblStatus.ForeColor = Color.Red; // Красный цвет для ошибки + } + } + + + + + + + private void экспортToolStripMenuItem_Click(object sender, EventArgs e) + { + if (emailTable == null || emailTable.Rows.Count == 0) + { + MessageBox.Show("Нет данных для экспорта.", "Ошибка"); + return; + } + + // Открываем диалог для выбора места сохранения файла + SaveFileDialog saveFileDialog = new SaveFileDialog + { + Filter = "Excel Files|*.xlsx", + Title = "Сохранить как", + FileName = "Emails.xlsx" + }; + + if (saveFileDialog.ShowDialog() == DialogResult.OK) + { + string filePath = saveFileDialog.FileName; + + try + { + OfficeOpenXml.ExcelPackage.LicenseContext = OfficeOpenXml.LicenseContext.NonCommercial; + + using (var package = new OfficeOpenXml.ExcelPackage()) + { + // Создаем новый лист + var worksheet = package.Workbook.Worksheets.Add("Emails"); + + // Записываем данные из DataTable в Excel + for (int i = 0; i < emailTable.Rows.Count; i++) + { + worksheet.Cells[i + 1, 1].Value = emailTable.Rows[i]["Email"]; // Первая строка без заголовка + } + + // Сохраняем файл + package.SaveAs(new FileInfo(filePath)); + } + + //MessageBox.Show("Данные успешно экспортированы!", "Успех"); + } + catch (Exception ex) + { + MessageBox.Show($"Ошибка при экспорте файла: {ex.Message}", "Ошибка"); + } + } + } + + private void помощьToolStripMenuItem_Click(object sender, EventArgs e) + { + MessageBox.Show("Инструкция по работе с программой\r\nПрограмма для работы с email-адресами позволяет удалять дубликаты из списка адресов и создавать отчёты об удалённых данных. Следуйте этим шагам:\r\n\r\n1. Импорт файла\r\nНажмите кнопку \"Импорт\" или выберите пункт меню \"Файл → Импорт\".\r\nВ появившемся окне выберите файл в формате .xlsx, содержащий список email-адресов.\r\nПрограмма загрузит данные и отобразит их в таблице.\r\n2. Удаление дубликатов\r\nПосле импорта нажмите кнопку \"Удалить дубликаты\".\r\nПрограмма автоматически:\r\nУдалит повторяющиеся email-адреса (с учётом регистра и пробелов).\r\nОбновит таблицу, оставив только уникальные адреса.\r\nСоздаст отчёт в папке MyAppReports в \"Моих документах\". Отчёт содержит список удалённых адресов.\r\n3. Экспорт файла\r\nЧтобы сохранить уникальные адреса, нажмите кнопку \"Экспорт\" или выберите пункт меню \"Файл → Экспорт\".\r\nВыберите место и имя для нового файла в формате .xlsx.\r\nПрограмма создаст файл с уникальными адресами.\r\n4. Папка отчётов\r\nВсе отчёты об удалённых адресах сохраняются в папке MyAppReports (расположена в \"Моих документах\").\r\nКаждый отчёт содержит:\r\nОбщее количество удалённых адресов.\r\nПолный список удалённых адресов.\r\nВы можете открыть эту папку вручную или добавить кнопку для её быстрого открытия."); + } } } diff --git a/NoDuplicate/Form1.resx b/NoDuplicate/Form1.resx new file mode 100644 index 0000000..d194c8e --- /dev/null +++ b/NoDuplicate/Form1.resx @@ -0,0 +1,171 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + 17, 17 + + + + + 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 + eLcAAAAASUVORK5CYII= + + + \ No newline at end of file diff --git a/NoDuplicate/NoDuplicate.csproj b/NoDuplicate/NoDuplicate.csproj index cc24c3c..24cecef 100644 --- a/NoDuplicate/NoDuplicate.csproj +++ b/NoDuplicate/NoDuplicate.csproj @@ -89,6 +89,9 @@ + + Form1.cs + ResXFileCodeGenerator Resources.Designer.cs