Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

gelöst VB.NET Lässt sich Excel Interop beschleunigen ?

Mitglied: RedWraith

RedWraith (Level 1) - Jetzt verbinden

10.03.2010 um 11:23 Uhr, 9026 Aufrufe, 4 Kommentare

Hallo Freunde !

Ich habe ein kleines Tool geschrieben, welches Berichte aus einer Datenbank erstellt und diese dem Nutzer anzeigt.

Nun möchte ich, dass der User die Möglichkeit hat, den Bericht in eine Excel Datei zu exportieren.
Meine Implementation über Microsoft.Office.Interop.Excel funktioniert auch, allerdings kommt diese mir langsam vor.
Ich brauche um eine 250 Zeilen lange, nachher etwa 50KB große Excel Tabelle zu exportieren etwa 15-20 Sekunden.
Wenn ich bedenke, dass ich auf einem Core2 Duo mit 4Gig Ram arbeite, kommt mir das zu langsam vor,
vorallem wenn ich daran denke, dass das Programm auch noch auf schwächeren Rechnern ausgeführt werden soll.


Meine Implementation sieht im Moment so aus:

01.
Private Sub SpeicherDateiXLS(ByVal pfad As String, Optional ByVal confirm As Boolean = False) 
02.
        Dim app As Excel.Application 
03.
        Dim wb As Excel.Workbook 
04.
        Dim ws As Excel.Worksheet 
05.
 
06.
        Dim i, j, cursor As Integer 
07.
 
08.
        Try 
09.
           app = New Excel.Application 
10.
            wb = app.Workbooks.Add() 
11.
            ws = wb.Sheets(1) 
12.
 
13.
            ws.Activate() 
14.
 
15.
            cursor = 1 
16.
 
17.
            With ws 
18.
 
19.
                For i = 0 To Me.dgvDeckblatt.Columns.Count - 1 
20.
                    .Cells(cursor, i + 1).value = Me.dgvDeckblatt.Columns(i).HeaderText 
21.
                Next 
22.
 
23.
                cursor += 1 
24.
 
25.
                For i = 0 To Me.dgvDeckblatt.Rows.Count - 1 
26.
                    For j = 0 To Me.dgvDeckblatt.Columns.Count - 1 
27.
                        .Cells(cursor, j + 1).value = ds(Me.dgvDeckblatt.Rows(i).Cells(j).Value) 
28.
                    Next 
29.
                    cursor += 1 
30.
                Next 
31.
 
32.
                cursor += 3 
33.
 
34.
                For i = 0 To Me.dgvPackliste.Columns.Count - 1 
35.
                    .Cells(cursor, i + 1).value = Me.dgvPackliste.Columns(i).HeaderText 
36.
                Next 
37.
 
38.
                cursor += 1 
39.
 
40.
                For i = 0 To Me.dgvPackliste.Rows.Count - 1 
41.
                    For j = 0 To Me.dgvPackliste.Columns.Count - 1 
42.
                        .Cells(cursor, j + 1).value = ds(Me.dgvPackliste.Rows(i).Cells(j).Value) 
43.
                    Next 
44.
                    cursor += 1 
45.
                Next 
46.
 
47.
                cursor += 3 
48.
 
49.
                For i = 0 To Me.dgvFehlmengen.Columns.Count - 1 
50.
                    .Cells(cursor, i + 1).value = Me.dgvFehlmengen.Columns(i).HeaderText 
51.
                Next 
52.
 
53.
                cursor += 1 
54.
 
55.
                For i = 0 To Me.dgvFehlmengen.Rows.Count - 1 
56.
                    For j = 0 To Me.dgvFehlmengen.Columns.Count - 1 
57.
                        .Cells(cursor, j + 1).value = ds(Me.dgvFehlmengen.Rows(i).Cells(j).Value) 
58.
                    Next 
59.
                    cursor += 1 
60.
                Next 
61.
 
62.
                .PageSetup.Zoom = False 
63.
                .PageSetup.FitToPagesWide = 1 
64.
                .PageSetup.FitToPagesTall = 99 
65.
 
66.
            End With 
67.
 
68.
            wb.SaveAs(pfad) 
69.
            wb.Close() 
70.
            app.Quit() 
71.
 
72.
            If confirm Then 
73.
                MsgBox("Bericht wurde gespeichert unter:" & vbCrLf & pfad) 
74.
            End If 
75.
 
76.
        Catch ex As Exception 
77.
            MessageBox.Show("Error: " + ex.ToString()) 
78.
        End Try 
79.
    End Sub
Gibt es eine Möglichkeit, das in Bezug auf Ausführgeschwindigkeit zu verbessern ?

Ich wäre für jeden Vorschlag dankbar.
Mitglied: problemsolver
10.03.2010 um 12:01 Uhr
Hallo,

mein Vorschlag:
1.) Exportiere die Werte in eine CSV-Datei. Dadurch benutzt Du nur die normalen Dateisystemfunktionen...
2.) Öffne die CSV mit Excel. Formatiere bzw Passe die Spalten dann an.

Das wird sicherlich viel viel schneller sein... schon mal über diesen Weg nachgedacht... Ok ich gebe zu, dass es etwas ungewöhnlich ist, aber "give it a try"

gruß

Markus
Bitte warten ..
Mitglied: RedWraith
10.03.2010 um 12:19 Uhr
Ah ich werds versuchen !

Interessanterweise hatte ich ursprünglich einen CSV Export implementiert, aber ich brauchte zusätzliche Formatierungen.
Ich melde mich zurück, wenns geklappt hat.
Bitte warten ..
Mitglied: 76109
10.03.2010 um 12:55 Uhr
Hallo RedWraith!

Da gibts doch sicher auch eine Range-Funktion und eventuell eine Copy-Funktion mit Destination oder Copy- und Paste-Funktion. In Excel würde man das sinngemäß in etwa so machen:
Range(Deckblatt.Cells(Zeile, Spalte 1), Deckblatt.Cells(Zeile, Deckblatt.Columns.Count)).Copy destination:=Excel.Cells(Zeile,Spalte)

Gruß Dieter
Bitte warten ..
Mitglied: RedWraith
10.03.2010 um 13:52 Uhr
Hallo Dieter,

Programmintern werden die Bericht als DataTable bzw. DataGridView behandelt, die haben keine .Cells Funktion, weil sie nicht Bestandteil des Objektbaumes von Excel sind.

Ich habe Markus Idee implementiert und der Umweg, die Dateien erst als CSV direkt zu schreiben und dann mit Excel zu konvertieren ist zwar etwas unelegant, ist aber deutlich schneller.


Lösung:
Man speichert das Ganze als CSV, öffnet es im Excel und speichert es dann als XLS. Source ist in etwa folgendes:
01.
csv="test.csv" 
02.
xls="test.xls" 
03.
app = New Excel.Application 
04.
wb = app.Workbooks.Open(csv) 
05.
ws = wb.Sheets(1) 
06.
 
07.
wb.SaveAs(xls, Excel.XlFileFormat.xlWorkbookNormal) 
08.
wb.Close(False) 
09.
app.Quit() 
10.
io.file.delete(csv)
Danke für die Hilfe !

Tim
Bitte warten ..
Ähnliche Inhalte
Microsoft Office

Excel 2007 Standardspeicherort lässt sich nicht ändern

Frage von leofabianMicrosoft Office

Hallo allerseits! Ich habe versucht in Excel 2007 unter Windows 7 den Standardspeicherort zu ändern, leider ohne Erfolg. Ich ...

VB for Applications

Excel Textkonvertierungs-Assistent läßt sich nicht unterdrücken

Frage von arotcivVB for Applications4 Kommentare

Hallo, ich habe hier in einer Excelmappe ein Makro, dass mir eine Textdatei in eine neue Arbeitsmappe einfügt. Ich ...

Router & Routing

WaWi über VPN beschleunigen

Frage von AndroxinRouter & Routing10 Kommentare

Moin, moin. Ich stehe momentan vor dem Problem, dass ein Client-Server basierte Warenwirtschaftssoftware über ein VPN genutzt werden soll. ...

Firewall

PfSense OpenVPN beschleunigen

Tipp von 108012Firewall

Hallo zusammen, ich nutze zwar nur ausschließlich IPSec VPN aber habe gerade mit einem Bekannten zusammen ein paar OpenVPN ...

Neue Wissensbeiträge
Windows 10

USB Maus und Tastatur versagen Dienst unter Windows 10

Erfahrungsbericht von hardykopff vor 2 TagenWindows 105 Kommentare

Da steht man ziemlich dumm da, wenn der PC sich wegen fehlender USB Tastatur und Maus nicht bedienen lässt. ...

Administrator.de Feedback
Update der Seite: Alles zentriert
Information von Frank vor 2 TagenAdministrator.de Feedback18 Kommentare

Hallo User, die größte Änderung von Release 5.8 ist das Zentrieren der Webseite (auf großen Bildschirmen) und ein "Welcome"-Teaser ...

Humor (lol)

WhatsApp-Nachrichten endlich auch per Bluetooth versendbar

Information von BassFishFox vor 3 TagenHumor (lol)4 Kommentare

Genau darauf habe ich gewartet! ;-) Der beliebte Messaging-Dienst WhatsApp erhält eine praktische neue Funktion: Ab dem nächsten Update ...

Google Android

Googles "Android Enterprise Recommended" für Unternehmen

Information von kgborn vor 3 TagenGoogle Android3 Kommentare

Hier eine Information, die für Administratoren und Verantwortliche in Unternehmen, die für die Beschaffung und das Rollout von Android-Geräten ...

Heiß diskutierte Inhalte
Router & Routing
Router auf Orginal Firmware zurück flashen mit Tftpd
Frage von ILeonardRouter & Routing21 Kommentare

Hallo, Ich habe zwei Router, einmal TP-Link 841n v11 und TP-Link 940N v5. Ich wollte fragen, ob jemand mir ...

Router & Routing
WRT keine Verbindung zum Web Interface
gelöst Frage von ILeonardRouter & Routing18 Kommentare

Hallo, Ich habe einen TP-Link WR841n mit wrt geflasht, das Problem ist ich kann mich mit 192.168.1.1 nicht verbinden. ...

Windows Server
Standortvernetzung zu einem Strato VServer (Windows)
Frage von matzefratze81Windows Server10 Kommentare

Moin, ich komme aus einem Enterprise-Umfeld und habe den Fehler gemacht, dass ich mich auf ein kleines Unternehmen eingelassen ...

TK-Netze & Geräte
Telefonie zweier Fritzboxen mit je eigenem DSL Anschluss verbinden
Frage von hannsgmaulwurfTK-Netze & Geräte10 Kommentare

Hallo zusammen, ich habe hier einen Haushalt mit zwei Anschlüssen. Einmal ISDN, einmal DSL. An jedem Anschluss hängt eine ...