Freigeben über


Vorgehensweise: Durchlaufen von Excel-Dateien und -Tabellen

Aktualisiert: 17. Juli 2006

Die Verfahren in diesem Thema beschreiben, wie mithilfe des Foreach-Schleifencontainers mit dem entsprechenden Enumerator die Excel-Arbeitsmappen in einem Ordner oder die Tabellen in einer Excel-Arbeitsmappe durchlaufen werden.

So durchlaufen Sie Excel-Dateien mithilfe des Foreach-Dateienumerators

  1. Erstellen Sie eine Zeichenfolgenvariable, die den aktuellen Excel-Pfad und -Dateinamen auf jeder Iteration der Schleife empfängt. (Im Beispielausdruck, der an späterer Stelle dieses Verfahrens gezeigt wird, wird der Variablenname ExcelFile verwendet.)

    ms345182.note(de-de,SQL.90).gifHinweis:
    Um Validierungsprobleme zu vermeiden, weisen Sie einen gültigen Excel-Pfad und einen Dateinamen als Anfangswert der Variablen zu.
  2. Erstellen Sie eine weitere Zeichenfolgenvariable für den Wert des Arguments Erweiterte Eigenschaften der Excel-Verbindungszeichenfolge. Dieses Argument enthält eine Reihe von Werten, die die Excel-Version angeben und bestimmen, ob die erste Zeile Spaltennamen enthält und ob der Importmodus verwendet wird. (Der Beispielausdruck, der weiter unten in diesem Verfahren dargestellt wird, verwendet den Variablennamen ExtProperties und weist einen Anfangswert von "Excel 8.0;HDR=Yes``" auf.)

  3. Fügen Sie der Registerkarte Ablaufsteuerung einen Foreach-Schleifencontainer hinzu. Informationen zum Konfigurieren des Foreach-Schleifencontainers finden Sie unter Vorgehensweise: Konfigurieren eines Foreach-Schleifencontainers.

  4. Wählen Sie auf der Seite Auflistung des Foreach-Schleifen-Editors den Foreach-Dateienumerator aus, geben Sie den Ordner an, in dem sich die Excel-Arbeitsmappen befinden, und geben Sie den Dateifilter an (normalerweise *.xls).

  5. Ordnen Sie auf der Seite Variablenzuordnungen Index 0 einer benutzerdefinierten Zeichenfolgenvariablen zu, die bei jeder Iteration der Schleife den aktuellen Excel-Pfad und Dateinamen empfangen wird. (Im weiter unten in diesem Verfahren gezeigten Beispielausdruck wird der Variablenname ExcelFile verwendet.)

  6. Schließen Sie den Foreach-Schleifen-Editor.

  7. Fügen Sie dem Paket einen Excel-Verbindungs-Manager hinzu wie unter Vorgehensweise: Hinzufügen eines Verbindungs-Managers zu einem Paket beschrieben. Wählen Sie für die Verbindung eine vorhandene Excel-Arbeitsmappendatei aus, um Überprüfungsfehler zu vermeiden.

    ms345182.note(de-de,SQL.90).gifWichtig:
    Wählen Sie im Verbindungs-Manager-Editor für Excel eine vorhandene Excel-Arbeitsmappe aus, um Überprüfungsfehler zu vermeiden, wenn Sie Tasks und Datenflusskomponenten konfigurieren, die diesen Excel-Verbindungs-Manager verwenden. Diese Arbeitsmappe wird vom Verbindungs-Manager zur Laufzeit nicht mehr verwendet, wenn Sie, wie in den folgenden Schritten beschrieben, einen Ausdruck für die ConnectionString-Eigenschaft konfigurieren. Nachdem Sie das Paket erstellt und konfiguriert haben, können Sie im Eigenschaftenfenster den Wert der ConnectionString-Eigenschaft löschen. Nach dem Löschen dieses Wertes ist jedoch die Eigenschaft der Verbindungszeichenfolge des Excel-Verbindungs-Managers erst wieder gültig, wenn die Foreach-Schleife ausgeführt wird. Daher müssen Sie für die Tasks, in denen der Verbindungs-Manager verwendet wird, oder für das Paket die DelayValidation-Eigenschaft auf True festlegen, um Überprüfungsfehler zu vermeiden.
  8. Wählen Sie den neuen Excel-Verbindungs-Manager aus, klicken Sie im Eigenschaftenfenster auf die Ausdrücke-Eigenschaft, und klicken Sie anschließend auf die Auslassungspunkte.

  9. Wählen Sie im Eigenschaftsausdrucks-Editor die ConnectionString-Eigenschaft aus, und klicken Sie anschließend auf die Auslassungspunkte.

  10. Geben Sie im Ausdrucks-Generator den folgenden Ausdruck ein:

    "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" +  @[User::ExcelFile] + ";Extended Properties=\"" + @[User::ExtProperties] + "\""
    

    Beachten Sie die Verwendung des Escapezeichens "\" bei den inneren Anführungszeichen, die um den Wert des Arguments für erweiterte Eigenschaften herum erforderlich sind.

  11. Erstellen Sie Tasks innerhalb des Foreach-Schleifencontainers, die den Excel-Verbindungs-Manager verwenden, um für alle Excel-Arbeitsmappen, die dem angegebenen Dateispeicherort und Dateimuster entsprechen, die gleichen Vorgänge auszuführen.

So durchlaufen Sie Excel-Tabellen mithilfe des Enumerators für Foreach-ADO.NET-Schemarowset

  1. Erstellen Sie einen ADO.NET-Verbindungs-Manager, der den Microsoft Jet OLE DB-Anbieter zum Herstellen einer Verbindung mit einer Excel-Arbeitsmappe verwendet. Stellen Sie auf der Seite Alle des Dialogfeldes Verbindungs-Manager sicher, dass Sie Excel 8.0 als Wert der Eigenschaft für erweiterte Eigenschaften eingeben. Weitere Informationen finden Sie unter Vorgehensweise: Hinzufügen eines Verbindungs-Managers zu einem Paket.

  2. Erstellen Sie eine Zeichenfolgenvariable, die bei jeder Iteration der Schleife den Namen der aktuellen Tabelle empfangen wird.

  3. Fügen Sie der Registerkarte Ablaufsteuerung einen Foreach-Schleifencontainer hinzu. Informationen zum Konfigurieren des Foreach-Schleifencontainers finden Sie unter Vorgehensweise: Konfigurieren eines Foreach-Schleifencontainers.

  4. Wählen Sie auf der Seite Auflistung des Foreach-Schleifen-Editors den Enumerator für Foreach-ADO.NET-Schemarowset aus.

  5. Wählen Sie als Wert für Verbindung den ADO.NET-Verbindungs-Manager aus, den Sie zuvor erstellt haben.

  6. Wählen Sie als Wert für Schema die Option Tabellen aus.

    ms345182.note(de-de,SQL.90).gifHinweis:
    Die Liste der Tabellen in einer Excel-Arbeitsmappe schließt sowohl Arbeitsmappen (diese weisen das Suffix $ auf) als auch benannte Bereiche ein. Wenn Sie die Liste nach nur Arbeitsmappen oder nach nur benannten Bereichen filtern müssen, müssen Sie zu diesem Zweck möglicherweise benutzerdefinierten Code in einem Skripttask schreiben. Weitere Informationen finden Sie unter Working with Excel Files with the Script Task.
  7. Ordnen Sie auf der Seite Variablenzuordnung den Index 2 der zuvor erstellten Zeichenfolgenvariablen zu, die den Namen der aktuellen Tabelle enthält.

  8. Schließen Sie den Foreach-Schleifen-Editor.

  9. Erstellen Sie Tasks innerhalb des Foreach-Schleifencontainers, die den Excel-Verbindungs-Manager verwenden, um für alle Excel-Tabellen in der angegebenen Arbeitsmappe die gleichen Vorgänge auszuführen. Wenn Sie einen Skripttask zum Überprüfen der aufgezählten Tabellennamen oder zum Arbeiten mit den Tabellen verwenden, müssen Sie die Zeichenfolgenvariable der ReadOnlyVariables-Eigenschaft des Skripttasks hinzufügen.

Siehe auch

Aufgaben

Vorgehensweise: Konfigurieren eines Foreach-Schleifencontainers
Vorgehensweise: Erstellen eines Eigenschaftsausdrucks

Konzepte

Excel-Verbindungs-Manager
Excel-Quelle
Excel-Ziel

Andere Ressourcen

Working with Excel Files with the Script Task

Hilfe und Informationen

Informationsquellen für SQL Server 2005