以指令碼工作偵測空的一般檔案
適用於:SQL Server Azure Data Factory 中的 SSIS Integration Runtime
一般檔案來源不會在嘗試處理一般檔案之前,判斷它是否包含資料列。 您可能會想要略過不包含任何資料列的檔案,藉以改善封裝的效率,尤其是逐一查看許多一般檔案的封裝。 指令碼工作可以在封裝開始處理資料流程之前,尋找空白的一般檔案。
注意
如果您想要建立可更輕鬆地在多個封裝之間重複使用的工作,請考慮使用此指令碼工作範例中的程式碼做為自訂工作的起點。 如需詳細資訊,請參閱 開發自訂工作。
描述
下列範例會使用 System.IO 命名空間的方法來測試一般檔案連線管理員中指定的一般檔案,以便判斷此檔案是否空白,或者它是否僅包含預期的非資料列,例如資料行標頭或空白的行。 此指令碼會先檢查檔案的大小。如果大小為零個位元組,表示檔案是空白的。 如果檔案大小大於零,此指令碼就會從檔案中讀取各行,直到沒有其他行為止,或者直到行數超過預期的非資料列數目為止。 如果檔案中的行數小於或等於預期的非資料列數目,此檔案就會被視為空白。 結果會以布林值的形式傳入使用者變數中,而這個變數的值可用於在封裝的控制流程中分支。 FireInformation 方法也會在 Microsoft Visual Studio Tools for Applications (VSTA) 的 [輸出] 視窗中顯示結果。
設定此指令碼工作範例
建立並設定名為 EmptyFlatFileTest 的一般檔案連線管理員。
建立名為
FFNonDataRows
的整數變數並將其值設定為一般檔案中預期的非資料列數目。建立名為
FFIsEmpty
的布林值變數。將
FFNonDataRows
變數新增至指令碼工作的 ReadOnlyVariables 屬性。將
FFIsEmpty
變數新增至指令碼工作的 ReadWriteVariables 屬性。在您的程式碼中,匯入 System.IO 命名空間。
如果您要使用 Foreach 檔案列舉值 (而非使用單一一般檔案連接管理員) 來逐一查看檔案,就必須修改下列範例程式碼,以便從儲存列舉值的變數 (而非從連接管理員) 中取得檔案名稱和路徑。
程式碼
Public Sub Main()
Dim nonDataRows As Integer = _
DirectCast(Dts.Variables("FFNonDataRows").Value, Integer)
Dim ffConnection As String = _
DirectCast(Dts.Connections("EmptyFlatFileTest").AcquireConnection(Nothing), _
String)
Dim flatFileInfo As New FileInfo(ffConnection)
' If file size is 0 bytes, flat file does not contain data.
Dim fileSize As Long = flatFileInfo.Length
If fileSize > 0 Then
Dim lineCount As Integer = 0
Dim line As String
Dim fsFlatFile As New StreamReader(ffConnection)
Do Until fsFlatFile.EndOfStream
line = fsFlatFile.ReadLine
lineCount += 1
' If line count > expected number of non-data rows,
' flat file contains data (default value).
If lineCount > nonDataRows Then
Exit Do
End If
' If line count <= expected number of non-data rows,
' flat file does not contain data.
If lineCount <= nonDataRows Then
Dts.Variables("FFIsEmpty").Value = True
End If
Loop
Else
Dts.Variables("FFIsEmpty").Value = True
End If
Dim fireAgain As Boolean = False
Dts.Events.FireInformation(0, "Script Task", _
String.Format("{0}: {1}", ffConnection, _
Dts.Variables("FFIsEmpty").Value.ToString), _
String.Empty, 0, fireAgain)
Dts.TaskResult = ScriptResults.Success
End Sub
public void Main()
{
int nonDataRows = (int)(Dts.Variables["FFNonDataRows"].Value);
string ffConnection = (string)(Dts.Connections["EmptyFlatFileTest"].AcquireConnection(null) as String);
FileInfo flatFileInfo = new FileInfo(ffConnection);
// If file size is 0 bytes, flat file does not contain data.
long fileSize = flatFileInfo.Length;
if (fileSize > 0)
{
int lineCount = 0;
string line;
StreamReader fsFlatFile = new StreamReader(ffConnection);
while (!(fsFlatFile.EndOfStream))
{
Console.WriteLine (fsFlatFile.ReadLine());
lineCount += 1;
// If line count > expected number of non-data rows,
// flat file contains data (default value).
if (lineCount > nonDataRows)
{
break;
}
// If line count <= expected number of non-data rows,
// flat file does not contain data.
if (lineCount <= nonDataRows)
{
Dts.Variables["FFIsEmpty"].Value = true;
}
}
}
else
{
Dts.Variables["FFIsEmpty"].Value = true;
}
bool fireAgain = false;
Dts.Events.FireInformation(0, "Script Task", String.Format("{0}: {1}", ffConnection, Dts.Variables["FFIsEmpty"].Value), String.Empty, 0, ref fireAgain);
Dts.TaskResult = (int)ScriptResults.Success;
}