Telefonino.net network
 
| HOMEPAGE | INDICE FORUM | REGOLAMENTO | ::. NEI PREFERITI .:: | RSS Forum | RSS News | NEWS web | NEWS software |
| PUBBLICITA' | | ARTICOLI | WIN XP | VISTA | WIN 7 | REGISTRI | SOFTWARE | MANUALI | RECENSIONI | LINUX | HUMOR | HARDWARE | DOWNLOAD | | CERCA nel FORUM » |

Torna indietro   WinTricks Forum > Software > Programmazione

Notices

Rispondi
 
Strumenti discussione
Vecchio 23-12-2008, 19.14.11   #1
giu_arg
Newbie
 
Registrato: 23-12-2008
Messaggi: 4
giu_arg promette bene
HELP!!Generare export Excel da IEnumerable

Ciao a tutti, sono nuovo del forum e mi sono affacciato da poco alla programmazione con c# . Di recente mi si è presentato un enorme problema, dovrei generare un file excel da un origine dati IEnumerable.
Il problema è che in qualsiasi modo faccio non ottengo il risultato desiderato cioè mi crea un file excel completamente vuoto.

Il codice della classe è:


namespace HRA_WF.ToolExportToExcel
{
public class ExportToExcel
{
public void dataGridView2Excel(DataGridView dataGridView, string pFullPath_toExport, string nameSheet)
{
Object obj = dataGridView.DataSource;
System.Data.DataTable dt = new System.Data.DataTable();

if (dataGridView.DataSource is IEnumerable)
{

IEnumerable ie = (IEnumerable)obj;
dt = (System.Data.DataTable)DataTableFromIenumerable(ie );
}
else if(dataGridView.DataSource is DataSet)
{
if (((System.Data.DataSet)dataGridView.DataSource).Ta bles.Count > 0)
dt = ((System.Data.DataSet)dataGridView.DataSource).Tab les[0];
else
dt = new System.Data.DataTable();
}
else if(dataGridView.DataSource is System.Data.DataTable)
{
dt = (System.Data.DataTable)dataGridView.DataSource;
}
dataTable2Excel(dt, dataGridView, pFullPath_toExport, nameSheet);
}


public void dataTable2Excel(System.Data.DataTable pDataTable, DataGridView dgv, string pFullPath_toExport, string nameSheet)
{
string vFileName = Path.GetTempFileName();
FileSystem.FileOpen(1, vFileName, OpenMode.Output, OpenAccess.Default, OpenShare.Default, -1);

string sb = string.Empty;
//si existe datagridview, tomar de él los nombres de columnas y la visibilidad de las mismas
if (dgv != null)
{
foreach (DataColumn dc in pDataTable.Columns)
{
System.Windows.Forms.Application.DoEvents();
string title = string.Empty;
if (dgv.Columns[dc.Caption] != null)
{
title = dgv.Columns[dc.Caption].HeaderText;
sb += title + ControlChars.Tab;
}
}
}
else
{
foreach (DataColumn dc in pDataTable.Columns)
{
System.Windows.Forms.Application.DoEvents();
string title = string.Empty;

title = dc.Caption;
sb += title + ControlChars.Tab;
}
}
FileSystem.PrintLine(1, sb);
int i = 0;
foreach (DataRow dr in pDataTable.Rows)
{
System.Windows.Forms.Application.DoEvents();
i = 0;
sb = string.Empty;

foreach (DataColumn dc in pDataTable.Columns)
{

if (dgv != null && dgv.Columns[dc.Caption] != null)
{
System.Windows.Forms.Application.DoEvents();

sb = sb + (Information.IsDBNull(dr[i]) ? string.Empty : FormatCell(dr[i])) + ControlChars.Tab;
}
else if (dgv == null)
{
System.Windows.Forms.Application.DoEvents();

sb = sb + (Information.IsDBNull(dr[i]) ? string.Empty : FormatCell(dr[i])) + ControlChars.Tab;
}
i++;
}
FileSystem.PrintLine(1, sb);
}
FileSystem.FileClose(1);
TextToExcel(vFileName, pFullPath_toExport, nameSheet);
}


private string FormatCell(Object cell)
{
string TextToParse = Convert.ToString(cell);
return TextToParse.Replace(",",string.Empty);
}


private void TextToExcel(string pFileName, string pFullPath_toExport, string nameSheet)
{
System.Globalization.CultureInfo vCultura = System.Threading.Thread.CurrentThread.CurrentCultu re;
System.Threading.Thread.CurrentThread.CurrentCultu re = System.Globalization.CultureInfo.CreateSpecificCul ture("it-IT");
Microsoft.Office.Interop.Excel.Application Exc = new Microsoft.Office.Interop.Excel.Application();
Exc.Workbooks.OpenText(pFileName, Missing.Value, 1,
XlTextParsingType.xlDelimited,
XlTextQualifier.xlTextQualifierNone,
Missing.Value, Missing.Value,
Missing.Value, true,
Missing.Value, Missing.Value,
Missing.Value, Missing.Value,
Missing.Value, Missing.Value,
Missing.Value, Missing.Value, Missing.Value);
Workbook Wb = Exc.ActiveWorkbook;
Worksheet Ws = (Worksheet)Wb.ActiveSheet;
Ws.Name = nameSheet;
try
{

Ws.get_Range(Ws.Cells[1, 1], Ws.Cells[Ws.UsedRange.Rows.Count, Ws.UsedRange.Columns.Count]).AutoFormat(XlRangeAutoFormat.xlRangeAutoFormatCl assic1, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
}
catch
{
Ws.get_Range(Ws.Cells[1, 1], Ws.Cells[Ws.UsedRange.Rows.Count, Ws.UsedRange.Columns.Count]);
}

string tempPath = Path.GetTempFileName();

pFileName = tempPath.Replace("tmp", "xls");
File.Delete(pFileName);

if (File.Exists(pFullPath_toExport))
{
File.Delete(pFullPath_toExport);
}
Exc.ActiveWorkbook.SaveAs(pFullPath_toExport, 1, null, null, null, null, XlSaveAsAccessMode.xlNoChange, null, null, null, null, null);

Exc.Workbooks.Close();
System.Runtime.InteropServices.Marshal.ReleaseComO bject(Ws);
Ws = null;
System.Runtime.InteropServices.Marshal.ReleaseComO bject(Wb);
Wb = null;
Exc.Quit(); System.Runtime.InteropServices.Marshal.ReleaseComO bject(Exc);
Exc = null;
GC.Collect();
GC.WaitForPendingFinalizers();
GC.Collect();
System.Threading.Thread.CurrentThread.CurrentCultu re = vCultura;
}



private System.Data.DataTable DataTableFromIenumerable(IEnumerable ien)
{
try
{
System.Data.DataTable dt = new System.Data.DataTable();
DataRow dr;
foreach (object obj in ien)
{
Type t = obj.GetType();
PropertyInfo[] pis = t.GetProperties();
if (dt.Columns.Count == 0)
{
foreach (PropertyInfo pi in pis)
{
if (!pi.Name.Equals("AsseY"))
{
dt.Columns.Add(pi.Name, pi.PropertyType);
}
}
}
dr = dt.NewRow();
foreach (PropertyInfo pi in pis)
{
object value = pi.GetValue(obj, null);
if (!pi.Name.Equals("AsseY"))
{
dr[pi.Name.ToString()] = value.ToString();
}
}
dt.Rows.Add(dr);
}
return dt;
}
catch (Exception ex)
{
Console.Write(ex.Message);
return null;
}
}

public static string readcell(Range oRange)
{
String result = string.Empty;
if (oRange != null)
{
if (oRange.Text != null)
{
result = oRange.Text.ToString();
}
}
return result;
}

}
}

La classe interessata è "DataTableFromIenumerable".... ( Il resto del codice lo ho preso da un altro sito)

Sarei enormemente grato se qualcuno mi sa dare qualche dritta per fare questo export!!!!

GRAZIE!!
giu_arg non è collegato   Rispondi citando
Vecchio 24-12-2008, 12.50.50   #2
giu_arg
Newbie
 
Registrato: 23-12-2008
Messaggi: 4
giu_arg promette bene
Grazie a tutti ma ho risolto il problema, se qualcuno vuole avere il codice completo me lo dica che lo posto
giu_arg non è collegato   Rispondi citando
Vecchio 04-06-2009, 01.51.04   #3
macprudens
Newbie
 
Registrato: 03-06-2009
Messaggi: 1
macprudens promette bene
CONVERSIONE IN VISUAL STUDIO 2005

SALVE,
POTRESTI CONVERTIRE IL CODICE IN VB 2005 ?

gRAZIE
macprudens non è collegato   Rispondi citando
Rispondi


Utenti attualmente attivi che stanno leggendo questa discussione: 1 (0 utenti e 1 ospiti)
 
Strumenti discussione

Regole di scrittura
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is ON
Gli smilies sono ON
[IMG] è ON
Il codice HTML è OFF

Vai al forum

Discussioni simili
Discussione Autore discussione Forum Risposte Ultimo messaggio
Free Word password / Excel password recovery crazy.cat Segnalazioni Web 4 03-03-2012 16.27.53
Trasformare Tabelle Excel o SQL in pardox o DB3 bepi Programmazione 0 11-12-2008 00.53.36
filtro file excel da un altro file excel chiopis Programmazione 1 09-01-2008 09.22.56
Microsoft Office Compatibility Pack per formati di file Word, Excel e PowerPoint 2007 crazy.cat Segnalazioni Web 0 19-01-2007 17.09.52
dimensione File EXCEL giobaxx Office suite 1 31-01-2006 23.34.59

Orario GMT +2. Ora sono le: 07.32.53.


E' vietata la riproduzione, anche solo in parte, di contenuti e grafica.
Copyright © 1999-2017 Edizioni Master S.p.A. p.iva: 02105820787 • Tutti i diritti sono riservati
L'editore NON si assume nessuna responsabilità dei contenuti pubblicati sul forum in quanto redatti direttamente dagli utenti.
Questi ultimi sono responsabili dei contenuti da loro riportati nelle discussioni del forum
Powered by vBulletin - 2010 Copyright © Jelsoft Enterprises Limited.