製品をチェック

無償トライアル:

無償トライアルへ

製品の情報と無償トライアルへ:

FTP Cmdlets

FTP にリアルタイムアクセスできる簡単に使えるPowerShell Cmdlets セット。Cmdlets を使って、SQL サーバーと同じようにリアルタイムデータを簡単に読み出し、書き込み、更新、および削除できます。

データ連携でお困りですか?

お問い合わせ

PowerShell Cmdlets でFTP データをCSV にエクスポート


標準PowerShell cmdlets を使ってFTP テーブルにアクセスして、CSV にエクスポート。


ftp ロゴ画像
powershell ロゴ画像

Cmdlets

PowerShell ロゴ画像

CData Cmdlets Module for FTP は、直感的なFTP データ連携を提供する標準cmdlet です。 本記事では、FTP Cmdlets を使ったサンプルを提供します。

FTP への接続を設定

FTP は、プレーンテキスト接続およびSSL/TLS 接続の両方をサポートします。FTP サーバーに接続するには、RemoteHost、User、およびPassword を指定します。SSLMode およびSSLServerCert を設定して、TSL/SSL による接続をセキュアにします。TLS/SSL を介した接続の設定について詳しくは、ヘルプドキュメントの「高度な設定」を参照してください。

次の接続プロパティを設定し、ファイルシステムのリレーショナルビューをコントロールします。

  • RemotePath:現在の作業ディレクトリに設定。
  • TableDepth:ビューとしてレポートするサブフォルダの深度を制御するために設定。
  • FileRetrievalDepth:ファイルを再帰的に取得し、Root テーブルにリストするために設定。

ストアドプロシージャ は、ファイル、のダウンロード、アップロード、およびプロトコルコマンドの送信に利用できます。 SQL を使用してサーバーと対話する方法の詳細については、ヘルプドキュメントの「データモデル」を参照してください。

$conn = Connect-FTP  -RemoteHost "$RemoteHost"

FTP データを取得してCSV にパイプライン

次の手順で、MyDirectory テーブルデータを取得して、結果をCSV ファイルにエクスポートします:

Select-FTP -Connection $conn -Table MyDirectory | Select -Property * -ExcludeProperty Connection,Table,Columns | Export-Csv -Path c:\myMyDirectoryData.csv -NoTypeInformation

このように、Select-FTP から取得した結果を、Select-Object cmdlet に流し、Export-Csv cmdlet に渡す前にいくつかのプロパティを除外しています。これは、CData Cmdlets が接続情報、テーブル、およびカラム情報が結果セットのそれぞれの"行"に挿入されるためです。それらの情報を表示したくない場合に、Export-Csv cmdlet に渡す前に除外を先に行い、それからCSV ファイルにエクスポートします。。

CData Cmdlets から、次のCmdlets にデータをパイプラインするところでは、接続、テーブル、カラムの情報が必要です。

データの削除

以下のように、指定に合致するレコードを削除することができます:

Select-FTP -Connection $conn -Table MyDirectory -Where "FilePath = /documents/doc.txt" | Remove-FTP

データの挿入と更新

CData Cmdlets は、データの加工やクレンジングを行うことができます。以下の手順では、CSV ファイルのデータを、挿入対象のオブジェクトに同じレコードが存在するかを確認した上で、存在する場合にはデータの更新、存在しない場合にはデータの挿入を行います。

Import-Csv -Path C:\MyMyDirectoryUpdates.csv | %{
  $record = Select-FTP -Connection $FTP -Table MyDirectory -Where ("Id = `'"+$_.Id+"`'")
  if($record){
    Update-FTP -Connection $ftp -Table MyDirectory -Columns ("Filesize","Filename") -Values ($_.Filesize, $_.Filename) -Where ("Id = `'"+$_.Id+"`'")
  }else{
    Add-FTP -Connection $ftp -Table MyDirectory -Columns ("Filesize","Filename") -Values ($_.Filesize, $_.Filename)
  }
}

このように、CData Cmdlets でデータ連携をシンプルに構成できます。Cmdlets では、モジュールのインストール、接続プロパティの設定だけで、データ連携の構築を始めることができます。是非、CData PowerShell Cmdlets の無償試用版をダウンロードして、シンプルかつパワフルなデータ連携を体感してください。