次の方法で共有


Excel ソース

Excel ソースは、 Microsoft Excel ブック内のワークシートまたは範囲からデータを抽出します。

Excel ソースでは、データを抽出するために、次の 4 つの異なるデータ アクセス モードが用意されています。

  • テーブルまたはビュー。

  • 変数で指定されたテーブルまたはビュー。

  • SQL ステートメントの結果。 クエリにはパラメーター化クエリを使用できます。

  • 変数に格納された SQL ステートメントの結果。

重要

Excel でのワークシートまたは範囲は、テーブルまたはビューに相当します。 Excel ソース エディターと Excel 変換先エディターで使用できるテーブルの一覧では、既存のワークシート (Sheet1$ など、ワークシート名に $ 記号を付加して識別) と名前付き範囲 (MyRange など、$ 記号が付かないことで識別) が表示されます。 詳細については、「使用に関する注意点」を参照してください。

Excel ソースは、Excel 接続マネージャーを使用してデータ ソースに接続します。Excel 接続マネージャーでは、使用する Excel ブック ファイルを指定します。 詳しくは、「 Excel Connection Manager」をご覧ください。

Excel ソースは、1 つの標準出力と 1 つのエラー出力をとります。

使用に関する注意点

Excel 接続マネージャーでは、Microsoft OLE DB Provider for Jet 4.0 とそのサポートされている Excel ISAM (Indexed Sequential Access Method) ドライバーを使用して、Excel データ ソースへのデータの接続と読み取りと書き込みを行います。

既存の Microsoft サポート技術情報の記事の多くは、このプロバイダーとドライバーの動作を文書化しています。また、これらの記事は Integration Services またはその先行データ変換サービスに固有のものではありませんが、予期しない結果を招く可能性がある特定の動作について知りたい場合があります。 Excel ドライバーの使用方法や動作に関する一般的な情報については、「 [HOWTO] Visual Basic または VBA から ADO を Excel データで使用する」を参照してください。

Jet プロバイダーを Excel ドライバーと共に使用した場合、次のような動作が原因で、Excel データ ソースのデータを読み取るときに予期しない結果が発生する場合があります。

  • データ ソース。 Excel ブックの変換元データには、ワークシートまたは名前付き範囲 (MyRange など) を使用できます。ワークシート名には $ 記号を付加する必要があります (Sheet1$ など)。 SQL ステートメントでは、$ 記号による構文エラーを回避するため、ワークシートの名前を [Sheet1$] などのように区切る必要があります。 クエリ ビルダーは、これらの区切り記号を自動的に付加します。 ワークシートまたは範囲を指定した場合、ドライバーは、ワークシートまたは範囲の左上の空でない最初のセルから、連続したセルのブロックを読み取ります。 したがって、ソース データには、タイトル行またはヘッダー行とデータ行との間に空の行を入れることはできません。

  • 欠損値。 Excel ドライバーは、指定した変換元の特定の行数 (既定では 8 行) を読み取り、各列のデータ型を推測します。 1 つの列に複数のデータ型が混在している可能性がある場合、特に数値データとテキスト データが混合している場合に、Excel ドライバーは数が多い方のデータ型を優先して判定し、それ以外のデータ型のデータが含まれるセルについては NULL 値を返します (同数の場合は、数値型が優先されます)。Excel ワークシートでのセル書式のほとんどのオプションは、このデータ型の判定に影響しません。 Excel ドライバーのこの動作を変更するには、インポート モードを指定します。 インポート モードを指定するには、[プロパティ] ウィンドウの Excel 接続マネージャーの接続文字列の [拡張プロパティ] の値に を追加IMEX=1します。 詳細については、「 [PRB] DAO の OpenRecordset を使用すると Excel の値として NULL が返される」をご覧ください。

  • テキストの切り捨て。 Excel の列にテキスト データが含まているとドライバーが判定した場合、ドライバーはサンプリングした最も長い値に基づいて、データ型 (文字列またはメモ) を選択します。 ドライバーがサンプリングした行で 255 文字より長い値が検出されなかった場合、その列はメモ列ではなく、255 文字の文字列の列として扱われます。 このため、255 文字より長い値があると、切り捨てられる場合があります。 切り捨てを発生させずにメモ列からデータをインポートするには、サンプリングされた行のうち 1 行以上のメモ列に、255 文字より長い値が含まれている状態にする必要があります。または、そのような行が含まれるように、ドライバーがサンプリングする行数を増やす必要があります。 サンプリングする行数を増やすには、 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel レジストリ キーの TypeGuessRows の値を増やします。 詳細については、「 [PRB] DTS: Jet 4.0 OLEDB からの転送がバッファーのオーバーフロー エラーで失敗」をご覧ください。

  • データ型。 Excel ドライバーでは、データ型の限定されたセットのみを認識します。 たとえば、すべての数値列は倍精度浮動小数点型 (DT_R8) として解釈され、すべての文字列の列 (メモ列以外) は 255 文字の Unicode 文字列 (DT_WSTR) として解釈されます。 Integration Services は、Excel データ型を次のようにマップします。

    • Numeric - 倍精度浮動小数点数 (DT_R8)

    • Currency - 通貨 (DT_CY)

    • Boolean - ブール (DT_BOOL)

    • 日付/時刻 - datetime (DT_DATE)

    • String - Unicode 文字列、長さ 255 (DT_WSTR)

    • Memo - Unicode テキスト ストリーム (DT_NTEXT)

  • データ型と長さの変換。 Integration Services では、データ型は暗黙的に変換されません。 したがって、派生列変換またはデータ変換の変換を使用して、Excel データを明示的に変換してから Excel 以外の変換先に読み込むか、Excel データを Excel 以外のデータに変換してから Excel 変換先に読み込む必要があります。 この場合、初期パッケージを作成する際に、必要な変換を構成できるインポート ウィザードおよびエクスポート ウィザードを使用すると便利な場合があります。 必要な変換の例を次に示します。

    • 特定のコードページを使用した Unicode Excel 文字列の列と Unicode 以外の文字列の列間の変換

    • 255 文字の Excel 文字列の列と異なる長さの文字列の列間の変換

    • 倍精度の Excel 数値列と他の型の数値列の列間の変換

Excel ソースの構成

プロパティを設定するには SSIS デザイナーから行うか、またはプログラムによって設定します。

[Excel ソース エディター] ダイアログ ボックスで設定できるプロパティの詳細については、次のトピックのいずれかを参照してください。

[詳細エディター] ダイアログ ボックスには、プログラムによって設定できるすべてのプロパティが反映されます。 [詳細エディター] ダイアログ ボックスまたはプログラムで設定できるプロパティの詳細については、次のトピックのいずれかを参照してください。

Excel ファイルのグループによるループ処理については、「 Foreach ループ コンテナーを使用して Excel のファイルおよびテーブルをループ処理する」をご覧ください。