Программирование регистратора данных – файл не создаетсяC#

Место общения программистов C#
Ответить
Anonymous
 Программирование регистратора данных – файл не создается

Сообщение Anonymous »

Контекст: я создаю проект для университета, и программирование не является моей «областью знаний». Это графический интерфейс, построенный на C# (Visual Studio).
Проблема: я пытался создать регистратор данных, который должен регистрировать все действия пользователя (вместе с отметкой времени) и сохранять это в файле .csv, но я не могу Кажется, я не могу заставить программу создать его. Он должен появиться на моем рабочем столе, как только я закрою приложение, и записать все, что я сделал. Если бы кто-нибудь здесь мог просто проверить и «посмотреть, имеет ли это смысл», возможно, указать, где это неправильно, это было бы здорово.
ПД: Извините, английский не мой родной язык. .
Это код, в котором, я думаю, кроется ошибка:
using ClosedXML.Excel;
using DocumentFormat.OpenXml.Drawing.Diagrams;

namespace Proyecto_controlLed_Servo
{
public partial class Form1 : Form
{
private List receivedDataList = new List();
private bool _isRunning = true;

public Form1()
{
CheckForIllegalCrossThreadCalls = false;
receivedDataList = new List();

SP1.DataReceived += new SerialDataReceivedEventHandler(SP1_DataReceived);
SP1.ErrorReceived += new SerialErrorReceivedEventHandler(SP1_ErrorReceived);
SP1.DataReceived += new SerialDataReceivedEventHandler(DataReceivedHandler);
LogAlert("Aplicación iniciada");
}

private void bCon_Click(object sender, EventArgs e)
{
try
{
if (!SP1.IsOpen)
{
SP1.PortName = CBPort.Text;
SP1.Open();
LogAlert("Conexión Establecida");
receivedDataList.Add("Conexión al puerto COM establecida.");

PBConexion.Value = 100;
enableComponents();
}
}
catch (Exception error)
{
MessageBox.Show("Error al conectarse al puerto: " + error.Message);
}
}

private void bDis_Click(object sender, EventArgs e)
{
if (SP1.IsOpen)
{
try
{
//Enviar comando para apagar steppers y cerrar puerto COM
SP1.WriteLine("l");
SP1.Close();
LogAlert("Gimb-App desconectado");
receivedDataList.Add("Se ha desconectado del puerto COM.");

MessageBox.Show("Entrada COM desconectada");
PBConexion.Value = 0;
labelEstado.Text = "Estado actual: Desconectado";
}
catch (Exception error)
{
MessageBox.Show("Error al desconectar el puerto: " + error.Message);
}
}
}

private void BRef_Click(object sender, EventArgs e)
{
try
{
string[] ports = SerialPort.GetPortNames();
CBPort.Items.Clear();
CBPort.Items.AddRange(ports);
if (ports.Length > 0)
{
CBPort.SelectedIndex = 0;
}
MessageBox.Show("Lista de puertos actualizada");
receivedDataList.Add("Se refrescó la lista de puertos COM.");
}
catch (Exception error)
{
MessageBox.Show("Error al refrescar la lista de puertos: " + error.Message);
}
}

//Método para registrar alertas
private void LogAlert(string message)
{
string timestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
receivedDataList.Add($"{timestamp}:{message}");
}

private void Form1_FormClosing(object sender, FormClosingEventArgs e)
{
if (SP1.IsOpen)
{
try
{
SP1.WriteLine("l");
SP1.Close();
}
catch (Exception error)
{
MessageBox.Show("Error al cerrar la aplicación: " + error.Message);
}
}
_isRunning = false;
SaveDataToCsv();
}

private void DataReceivedHandler(object sender, SerialDataReceivedEventArgs e)
{
if (!_isRunning) return;

try
{
string data = SP1.ReadLine();
receivedDataList.Add("Dato recibido: " + data);
Console.WriteLine("Dato recibido: " + data);
}
catch (Exception error)
{
receivedDataList.Add("Error al recibir datos: " + error.Message);
}
}

private void SaveDataToCsv()
{
try
{
string desktopPath = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
string filePath = Path.Combine(desktopPath, "RegistroGimb.csv");
string csvFilePath = Path.ChangeExtension(filePath, ".csv");

using (var workbook = new XLWorkbook())
{
var worksheet = workbook.Worksheets.Add("Registros");
worksheet.Cell(1, 1).Value = "Registro de Actividades";
for (int i = 0; i < receivedDataList.Count; i++)
{
worksheet.Cell(i + 2, 1).Value = receivedDataList;
}

workbook.SaveAs("RegistroGimb.xlsx"); //guardar como archivo .xlsx
}

ConvertXlsxToCsv(filePath, csvFilePath);

MessageBox.Show("Registro de alertas guardado en {filePath}");
}
catch (Exception error)
{
MessageBox.Show("Error al escribir en el archivo de registro: " + error.Message);
}
}

private void ConvertXlsxToCsv(string filePath, string csvFilePath)
{
try
{
using (var workbook = new XLWorkbook(filePath))
{
var worksheet = workbook.Worksheet(1);

using (var writer = new StreamWriter(csvFilePath))
{
foreach (var row in worksheet.RowsUsed())
{
var cells = row.CellsUsed().Select(c => c.GetValue());
var line = string.Join(",", cells);
writer.WriteLine(line);
}
}
}
}
catch (Exception error)
{
MessageBox.Show("Error al convertir el archivo a CSV: " + error.Message);
}
}

//Método para lectura de puerto serie
private void SP1_DataReceived(object sender, SerialDataReceivedEventArgs e)
{
try
{
string data = SP1.ReadLine();

if (data.Contains("Movimiento detectado"))
{
LogAlert("Movimiento detectado");
}
else if (data.Contains("Motor endendido"))
{
LogAlert("Motor encendido");
}
else if (data.Contains("Motor apagado"))
{
LogAlert("Motor apagado");
}
else if (data.Contains("Conexión establecida"))
{
LogAlert("Conexión establecida");
}
else if (data.Contains("Desconexion"))
{
LogAlert("Desconexión del puerto COM");
}
else
{
LogAlert("Dato recibido: " + data);
}
}
catch (Exception error)
{
MessageBox.Show("Error al leer datos del puerto serie: " + error.Message);
LogAlert("Error al leer datos del puerto serie: " + error.Message);
}
}



Подробнее здесь: https://stackoverflow.com/questions/791 ... reate-file
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»