Duda con ruta al exportar a Excel (C#) [SOLUCIONADO]

Iniciado por Hartigan, 2 Septiembre 2010, 21:05 PM

0 Miembros y 1 Visitante están viendo este tema.

Hartigan

Hola amig@s. Tengo un pequeño problema.

Estoy haciendo que se puedan exportar los datos de un datagridview a varios formatos y uno de ellos es excel. El caso es que no se como ponerle la ruta que yo queira donde guardar el fichero de destino. Es decir yo quiero que se guarde en una ruta que especifico en un textbox, pero no se como hacerlo.

Mi código por si sirve de algo es:

Código (csharp) [Seleccionar]

.....                
               Excel.Application xlApp;
               Excel.Workbook xlWorkBook;
               Excel.Worksheet xlWorkSheet;
               
               object misValue = System.Reflection.Missing.Value;

               try
               {
                   xlApp = new Excel.ApplicationClass();
                   xlWorkBook = xlApp.Workbooks.Add(misValue);
                   xlWorkSheet = (Excel.Worksheet)xlWorkBook.Worksheets.get_Item(1);
                   int i = 0;
                   int j = 0;

                   for (i = 0; i < dataGridView1.Columns.Count; i++)
                   {
                       if (dataGridView1.Columns[i].Visible == true)
                       {
                           xlWorkSheet.Cells[1, i] = dataGridView1.Columns[i].HeaderText;
                       }
                   }

                   for (i = 0; i <= dataGridView1.RowCount - 1; i++)
                   {
                       for (j = 1; j <= dataGridView1.ColumnCount - 1; j++)
                       {
                           DataGridViewCell cell = dataGridView1[j, i];
                           xlWorkSheet.Cells[i + 2, j] = cell.Value;
                       }
                   }

                   xlWorkBook.SaveAs(textBoxDestino.Text + "\\" + textBoxNombre.Text, Excel.XlFileFormat.xlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue);
                   xlWorkSheet.Columns.AutoFit();
                   xlWorkBook.Close(true, misValue, misValue);
                   xlApp.Quit();

                   releaseObject(xlWorkSheet);
                   releaseObject(xlWorkBook);
                   releaseObject(xlApp);

                   MessageBox.Show("Archivo Excel creado con éxito", "Información", MessageBoxButtons.OK, MessageBoxIcon.Information);
               }
               catch (Exception ex)
               {
                   MessageBox.Show("No se ha podido crear el archivo Excel", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
               }
.....


A ver si me podeis ayudar. Salu2. xD

raul338

Cita de: Hartigan en  2 Septiembre 2010, 21:05 PM
Código (csharp) [Seleccionar]

using System.IO;

//............
if (!Directory.Exits(textBoxDestino.Text)) {
   try {
      Directory.CreateDirectory(textBoxDestino.Text);
   } catch {
      MessageBox.Show("Directorio no valido");
      return;
   }
}
xlWorkBook.SaveAs(textBoxDestino.Text + "\\" + textBoxNombre.Text, Excel.XlFileFormat.xlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue);
.....


A ver si me podeis ayudar. Salu2. xD

Fijate si te sirve :)

Hartigan

#2
No, eso no funciona, más que nada porque no afecta a la configuración del excel... Crearia una carpeta sin más en el sistema pero ahi no guardaría el archivo. lol. xDD

gracias de todos modos. Alguna solución más?

EDITO: ya lo he conseguido. es tan secillo como poner:

Código (csharp) [Seleccionar]

...
string filename = this.textboxDestino.Text + "\\" + this.textBoxNombre.Text;
...
....
xlWorkBook.SaveAs(@filename, Excel.XlFileFormat.xlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue);

....


Salu2. ;)