Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Prestandaproblem med excel

Postades av 2006-06-15 17:40:46 - Tobias Gladh, i forum asp.net generellt, Tråden har 0 Kommentarer och lästs av 655 personer

Jag har följande kod som skapar en excel fil från dynamisk data. Problemet är att det tar väldigt lång tid 1min 48s för tusen rader. Sedan ligger processen EXCEL.exe kvar om man kikar i Aktivitetshanteraren fast jag har kod som ska ta bort det.

Nån som har tips om prestandaökning och processavslut?

Jag har ersatt vissa av värdena om ni undrar varför det bara står "värde" i insättningen i cellerna, dessa är alla av typen varchar annars så inga speciella datatyper används.
<code>
Dim oXL As Excel.Application
Dim oWB As Excel.Workbook
Dim oSheet As Excel.Worksheet
'Dim oRng As Excel.Range
Try
GC.Collect()
' Start Excel and get Application object.
oXL = New Excel.Application()
oXL.Visible = True
oXL.UserControl = True
Dim oldCI As System.Globalization.CultureInfo = _
System.Threading.Thread.CurrentThread.CurrentCulture
System.Threading.Thread.CurrentThread.CurrentCulture = _
New System.Globalization.CultureInfo("en-US")
'oXL.Workbooks.Add()
oWB = oXL.Workbooks.Add(Missing.Value)

oSheet = oWB.ActiveSheet
oSheet.Cells(1, 1).Value = "värde"
oSheet.Cells(1, 2).Value = "värde"
oSheet.Cells(1, 3).Value = "värde"
oSheet.Cells(1, 4).Value = "värde"
oSheet.Cells(1, 5).Value = "värde"
oSheet.Cells(1, 6).Value = "värde"
oSheet.Cells(1, 7).Value = "värde"
oSheet.Cells(1, 8).Value = "värde"
oSheet.Cells(1, 9).Value = "värde"
oSheet.Cells(1, 10).Value = "värde"
oSheet.Cells(1, 11).Value = "värde"
oSheet.Cells(1, 12).Value = "värde"
oSheet.Cells(1, 13).Value = "värde"
oSheet.Cells(1, 14).Value = "värde"
'oSheet.get_Range("A1", "N1").Font.Bold = True
'oSheet.get_Range("A1", "N1").ColorIndex = 15
'oSheet.get_Range("A1", "N1").Pattern = xlSolid
cmd.Connection.Open()
Dim myReader As SqlDataReader = cmd.ExecuteReader
Dim i As Integer = 2
While myReader.Read
oSheet.Cells(i, 1).Value = myReader("värde")
oSheet.Cells(i, 2).Value = myReader("värde")
oSheet.Cells(i, 3).Value = myReader("värde")
oSheet.Cells(i, 4).Value = myReader("värde")
oSheet.Cells(i, 5).Value = myReader("värde")
oSheet.Cells(i, 6).Value = myReader("värde")
oSheet.Cells(i, 7).Value = myReader("värde")
oSheet.Cells(i, 8).Value = myReader("värde")
oSheet.Cells(i, 9).Value = myReader("värde")
oSheet.Cells(i, 10).Value = myReader("värde")
oSheet.Cells(i, 11).Value = myReader("värde")
oSheet.Cells(i, 12).Value = myReader("värde")
oSheet.Cells(i, 13).Value = myReader("värde")
oSheet.Cells(i, 14).Value = myReader("värde")
i = i + 1
End While
myReader.Close()
myReader = Nothing
cmd.Connection.Close()

oWB.SaveAs(filePath, Excel.XlFileFormat.xlWorkbookNormal, Missing.Value, Missing.Value, False, False, Excel.XlSaveAsAccessMode.xlShared, False, False, Missing.Value, Missing.Value, Missing.Value)
' Need all following code to clean up and extingush all references!!!
oWB.Close(Missing.Value, Missing.Value, Missing.Value)
oXL.Workbooks.Close()
oXL.Quit()
'System.Runtime.InteropServices.Marshal.ReleaseComObject(oRng)
System.Runtime.InteropServices.Marshal.ReleaseComObject(oXL)
System.Runtime.InteropServices.Marshal.ReleaseComObject(oSheet)
System.Runtime.InteropServices.Marshal.ReleaseComObject(oWB)
oSheet = Nothing
oWB = Nothing
oXL = Nothing
GC.Collect() ' force final cleanup!
System.Threading.Thread.CurrentThread.CurrentCulture = oldCI
errLabel.Text = "Hämta excelfil"
Catch exc As Exception
Dim errorMessage As String
errorMessage = "Fel: "
errorMessage = String.Concat(errorMessage, exc.Message)
errorMessage = String.Concat(errorMessage, " Rad: ")
errorMessage = String.Concat(errorMessage, exc.Source)
errLabel.Text = errorMessage
End Try
</code>


Svara

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 602
27 953
271 705
4 035
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies