Oprettet fre. d. 03. september 2010 kl. 10:55:54

thomasso (nedlagt brugerprofil)

DataTable til Excel fejler med System.UnauthorizedAccessException

Hejsa.

Er ved at lave en lille funktion, der henter nogle poster ud i en DataTable, hvor indholdet af denne så skal lægges over i et Excel ark.

Men det fejler når der forsøges at oprette og skrive til Excel-arket med følgende fejl:

System.UnauthorizedAccessException: Retrieving the COM class factory for component with CLSID {00024500-0000-0000-C000-000000000046} failed due to the following error: 80070005. at Orders_Custom_Order_List.btn_GetOrdersForExcel_Click(Object sender, EventArgs e)

Nogen der ved hvad denne fejl betyder? Altså ud over at jeg tilsyneladende ikke har rettigheder til at gøre det...

Min kode, hvor selve oprettelsen og skrivningen til Excel forsøges ser således ud:

// Opret Excel sheet fra DataTable
                Excel.Application oXL;
                Excel.Workbook oWB;
                Excel.Worksheet oSheet;
                Excel.Range oRange;

                // Start Excel and get Application object.
                oXL = new Excel.Application();

                // Set some properties
                oXL.Visible = true;
                oXL.DisplayAlerts = false;

                // Get a new workbook.
                oWB = oXL.Workbooks.Add(Missing.Value);

                // Get the active sheet
                oSheet = (Excel.Worksheet)oWB.ActiveSheet;
                oSheet.Name = "Orders";

                // Process the DataTable
                int rowCount = 1;
                foreach (DataRow dr in dtOrders.Rows)
                {
                    rowCount += 1;
                    for (int i = 1; i < dtOrders.Columns.Count + 1; i++)
                    {
                        // Add the header the first time through
                        if (rowCount == 2)
                        {
                            oSheet.Cells[1, i] = dtOrders.Columns[i - 1].ColumnName;
                        }
                        oSheet.Cells[rowCount, i] = dr[i - 1].ToString();
                    }
                }

                // Resize the columns
                oRange = oSheet.get_Range(oSheet.Cells[1, 1],
                oSheet.Cells[rowCount, dtOrders.Columns.Count]);
                oRange.EntireColumn.AutoFit();

                // Save the sheet and close
                oSheet = null;
                oRange = null;
                oWB.SaveAs(Server.MapPath("../Invoices/Excel/test.xls"), Excel.XlFileFormat.xlWorkbookNormal,
                    Missing.Value, Missing.Value, Missing.Value, Missing.Value,
                    Excel.XlSaveAsAccessMode.xlExclusive,
                    Missing.Value, Missing.Value, Missing.Value,
                    Missing.Value, Missing.Value);
                oWB.Close(Missing.Value, Missing.Value, Missing.Value);
                oWB = null;
                oXL.Quit();

                // Clean up
                // NOTE: When in release mode, this does the trick
                GC.WaitForPendingFinalizers();
                GC.Collect();
                GC.WaitForPendingFinalizers();
                GC.Collect();

Selve hentningen af data og opbygningen af DataTable fungerer fint når jeg udskriver det i et GridView, men kan altså åbenbart ikke finde ud af at få det over i Excel :-)
P.S. Selve koden herover er ikke noget jeg selv har lavet, men fundet på nettet og det burde altså virke...

Skrevet fre. d. 03. september 2010 kl. 16:21:02| #1

Lukker. Jeg fik sat debug til og fandt ud af at det var noget permission på noget med Excel. Gik ikke længere ind i det, da jeg samtidig fandt ud af at webhotellet jeg benytter slet ikke understøtter det jeg forsøgte at lave :-)

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Koordinater for nyt vindue efter scroll, csharp.

Oprettet den 11. februar 2012 kl. 01.54
bjarnefilm giver 30 point for svar | Giv et svar »

Treeview hovedmenu á lá Dynamics C5

Oprettet den 10. februar 2012 kl. 08.12
olehaahr giver 30 point for svar | Giv et svar »

Deployment på Windows Mobile 6.5

Oprettet den 9. februar 2012 kl. 13.59
schristensen giver 200 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger