Después de un tiempo, volvemos a publicar un nuevo Demo, esta vez a pedido de un alumno, que desea copiar que su aplicación tenga la funcionalidad de copiar datos de la Grilla (DataGridView) a Excel (esto es automático, no es necesario programar nada) y desde Excel hacia la aplicación (esto si requiere de programar usando el objeto Clipboard de WinForms).
Como siempre nuestro desarrollo lo haremos con Listas de Objetos (como debe ser para ahorrar memoria y no con DataSet), ademas usaremos Reflection para convertir los datos que vienen como cadenas desde Excel al tipo de datos adecuado del objeto.
Crear una Aplicación Windows Forms en C#
Crear un nuevo proyecto de tipo Windows Forms y llamarle "CopiarExcel". Cambiarle de nombre al formulario por el de "frmProducto".
Crear la clase: "beProducto" para la lista de objetos
using System;
namespace CopiarExcel
{
public class beProducto
{
public int IdProducto { get; set; }
public string Nombre { get; set; }
public decimal Precio { get; set; }
public short Stock { get; set; }
}
}
Agregar un control DataGridView sobre el formulario, cambiarle al nombre de "dgvProducto" y acoplarlo para que se vea similar a la siguiente figura:
Escribir el siguiente código en el formulario:
using System.IO;
using System.Reflection;
namespace CopiarExcel
{
public partial class frmProducto : Form
{
private List<beProducto> lbeProducto;
public frmProducto()
{
InitializeComponent();
}
private void cargarProductos(object sender, EventArgs e)
{
lbeProducto = new List<beProducto>();
Random oRandom = new Random();
beProducto obeProducto;
for(int i=1;i<=10;i++)
{
obeProducto = new beProducto();
obeProducto.IdProducto = i;
obeProducto.Nombre = String.Format("Producto {0}", i);
obeProducto.Precio = oRandom.Next(100)+10;
obeProducto.Stock = (short)(oRandom.Next(10) + 1);
lbeProducto.Add(obeProducto);
}
dgvProducto.DataSource = lbeProducto;
}
private void pegarExcel(object sender, KeyEventArgs e)
{
if (e.Control && e.KeyCode == Keys.V)
{
string formato = DataFormats.CommaSeparatedValue;
object contenido = Clipboard.GetData(formato);
if (contenido != null && contenido is MemoryStream)
{
byte[] buffer;
using (MemoryStream ms = (MemoryStream)contenido) buffer = ms.ToArray();
string lista = Encoding.UTF8.GetString(buffer).Replace("\r\n", ",");
string[] data = lista.Split(',');
PropertyInfo[] propiedades = lbeProducto[0].GetType().GetProperties();
if ((data.Length - 1) % propiedades.Length == 0)
{
beProducto obeProducto = null;
PropertyInfo propiedad;
int c = 0;
Type tipo = null;
while (c < data.Length - 1)
{
for (int i = 0; i < propiedades.Length; i++)
{
if (i == 0) obeProducto = new beProducto();
propiedad = obeProducto.GetType().GetProperty(propiedades[i].Name);
tipo = propiedad.PropertyType;
propiedad.SetValue(obeProducto, Convert.ChangeType(data[c], tipo));
if (i == propiedades.Length - 1) lbeProducto.Add(obeProducto);
c++;
}
}
dgvProducto.DataSource = null;
dgvProducto.DataSource = lbeProducto;
}
else MessageBox.Show
("Numero de columnas a copiar del Excel y la Grilla deben ser iguales");
}
else MessageBox.Show("No hay un rango de celdas a copiar");
}
}
}
}
Nota: Para copiar desde Excel a la grilla se debe pulsar la tecla Ctrl + V y la cantidad de columnas debe ser la misma que la de la grilla (en realidad la de las propiedades de la clase beProducto o la que fuera).
Probar la Aplicación Creada
Grabar el proyecto y ejecutarlo con F5. Se mostrará la siguiente ventana con los datos de los productos creados en el evento Load del formulario:
Crear un archivo de Excel con la misma estructura de los Productos, tal como se muestra a continuación:
Copiar (Ctrl + C) el rango de celdas que se desea llevar a la aplicación (sin incluir las cabeceras) y en cualquier celda de la grilla Pegar (Ctrl + V), y se copiaran los registros seleccionados en Excel, tal como se muestra a continuación:
Si desean se puede ir copiando por partes (filas) pero si es necesario seleccionar todas las columnas, ya que el objeto necesita de valores.
Nota: El procedimiento contrario, es decir desde la Aplicación (DataGridView) a Excel es automatico, solo hay que marcar el rango de celdas del DataGridView, Ctrl + C y luego en Excel Ctrl + V.
Comentario Final
En este post hemos visto como agregar la funcionalidad de Copiar Datos Externos a la aplicación, en este caso desde Excel, pero el procedimiento sera similar desde cualquier origen. Para ello hemos usado el objeto ClipBoard y para trabajar con objetos hemos usado Reflection, lo que quiere decir que el demo lo puedes probar con cualquier objeto que definan.
Saludos a todos los visitantes asiduos del Blog y ya saben que pueden hacer sus pedidos en los comentarios.
Descarga: