vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
sevDataGrid - Gönnen Sie Ihrem SQL-Kommando diesen krönenden Abschluß!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
Zugriff auf Excel-Arbeitsmappe mit VB2005 
Autor: Earny
Datum: 19.03.10 19:47

Hallo,
ich schreibe aus VB2005 heraus 10000 Werte zu Testzwecken in eine Excel-Tabelle. Ich schreibe jeweils die Zahlen 1 bis 10000 in 10 Spalten a 1000 Zeilen. Das funktioniert auch mit beiden Programmvarianten.
Die Variante 1 arbeitet mit später Bindung, Variante 2 mit früher Bindung.
Bei der Variante 1 beträgt die Zeit zum Schreiben der 10000 Werte ca. 62 s, die Variante 2 benötigt ca. 125 s. Die Variante mit später Bindung ist also doppelt so schnell.
Mit der Progressbar pgbAnzeige lass ich mir den Schreibfortschritt anzeigen.
Mich würde interessieren, wo dieser Geschwindigkeitsunterschied herrührt.

Variante 1:
Option Explicit On
Option Strict Off
 
Public Class Form1
 
    Dim Exc As Object
 
    Private Sub Form1_Load(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles MyBase.Load
        Exc = GetObject(CurDir() & "\Mappe1.xls")
        Exc.Application.Visible = True
        Exc.Windows(1).Visible = True
        Me.Activate()
    End Sub
 
    Private Sub btnWerteSchreiben_Click(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles btnWerteSchreiben.Click
        Dim i, j, n As Integer
        Dim k(9999) As Integer
        For n = 0 To 9999
            k(n) = n + 1
        Next
        pgbAnzeige.Visible = True
        pgbAnzeige.Maximum = 10000
        n = 0
        For j = 0 To 9
            For i = 0 To 999
                Exc.worksheets(1).cells(i + 1, j + 1).Value = k(n)
                n = n + 1
                pgbAnzeige.Value = n
            Next
        Next
        pgbAnzeige.Visible = False
    End Sub
 
End Class
Variante 2:
Option Explicit On
Option Strict Off
 
Imports Microsoft.Office.Interop
 
Public Class Form1
 
    Dim xlApp As New Excel.Application
    Dim xlMap As Excel.Workbook
 
    Private Sub Form1_Load(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles MyBase.Load
        xlMap = xlApp.Workbooks.Open(CurDir() & "\Mappe1.xls")
        xlApp.Application.Visible = True
        Me.Activate()
    End Sub
 
    Private Sub btnWerteSchreiben_Click(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles btnWerteSchreiben.Click
        Dim i, j, n As Integer
        Dim k(9999) As Integer
        For n = 0 To 9999
            k(n) = n + 1
        Next
        pgbAnzeige.Visible = True
        pgbAnzeige.Maximum = 10000
        n = 0 'n=0 muss sein
        For j = 0 To 9
            For i = 0 To 999
                xlMap.Worksheets(1).cells(i + 1, j + 1).Value = k(n)
                n = n + 1
                pgbAnzeige.Value = n
            Next
        Next
        pgbAnzeige.Visible = False
    End Sub
 
End Class
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Zugriff auf Excel-Arbeitsmappe mit VB20051.380Earny19.03.10 19:47

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel