tFTPFileList
each of them by connecting to a remote directory via an FTP protocol.
tFTPFileList Standard properties
These properties are used to configure tFTPFileList running in the Standard Job framework.
The Standard
tFTPFileList component belongs to the Internet family.
The component in this framework is generally available.
Basic settings
Property Type |
Either Built-in or Repository. |
|
Built-in: No property data stored |
|
Repository: Select the Repository |
Use an existing connection/Component List |
Select this check box and in the Component |
Host |
FTP IP address. |
Port |
Listening port number of the FTP server. |
Username and Password |
User authentication information. To enter the password, click the […] button next to the |
Remote directory |
Path to the remote directory. |
Move to the current directory |
This option appears when Use an existing |
File detail |
Select this check box if you want to display the details of each type of rights on the file/folder, name of the author, name of |
SFTP Support |
Select this check box to connect to the FTP server via an SFTP connection. The following
Authentication method: Select the SFTP authentication
method, either Public key or Password.
Filename encoding: Select this check box to set the
encoding used to convert file names from Strings to bytes. It should be the same encoding used on the SFTP server. Note:
If the SFTP server’s version is greater than 3, the encoding should be UTF-8, or |
Files |
Click the plus button to add the lines you want to use as filters:
Filemask: enter the filename or |
Connection Mode |
Select the SFTP connection mode you want to use:
Active: You determine the
Passive: the FTP server determines |
Encoding |
Select an encoding type from the list, or select Custom |
Global Variables
Global Variables |
ERROR_MESSAGE: the error message generated by the
CURRENT_FILE: the current file name. This is a Flow
CURRENT_FILEPATH: the current file path. This is a Flow
NB_FILE: the number of files processed. This is an After A Flow variable functions during the execution of a component while an After variable To fill up a field or expression with a variable, press Ctrl + For further information about variables, see |
Usage
Usage rule |
This component is typically used as a single-component sub-job but |
Limitation |
Due to license incompatibility, one or more JARs required to use this component are not |
Scenario: Listing and getting files/folders on an FTP directory
files and folders on an FTP server directory, and then get only text files on that directory
to a local directory.
Creating a Job for listing and getting files/folders on an FTP directory
Create a Job to connect to an FTP server, iterate and list all files
and folders on an FTP root directory, then get only text files on the FTP root directory to
a local directory, finally close the connection to the server.

scenario, an FTP server must be started and a couple of files/folders must be put onto
the root directory of the FTP server.

-
Create a new Job and add a tFTPConnection component, a tFTPFileList component, a tIterateToFlow component, a tLogRow
component, a tFTPGet component, and a tFTPClose component by typing their names in the design
workspace or dropping them from the Palette. -
Link the tFTPFileList component to the
tIterateToFlow component using a Row > Iterate
connection. -
Link the tIterateToFlow component to
the tLogRow component using a Row > Main connection. -
Link the tFTPConnection component to
the tFTPFileList component using a Trigger > OnSubjobOk
connection. -
Do the same to link the tFTPFileList
component to the tFTPGet component, and the
tFTPGet component to the tFTPClose component.
Opening a connection to the FTP server
server.
-
Double-click the tFTPConnection
component to open its Basic settings view. -
In the Host and Port fields, enter the FTP server IP address and the listening port
number respectively. - In the Username and Password fields, enter the authentication details.
Listing all files/folders on the FTP root directory
Configure the tFTPFileList
component, the tIterateToFlow component, and the
tLogRow component to iterate all files and folders on
the FTP root directory and display the names and paths of these files and folders on the
console of
Talend Studio
.
-
Double-click the tFTPFileList
component to open its Basic settings view. -
Specify the connection details required to access the FTP server. In
this example, select the Use an existing connection
check box and from the Component list drop-down
list displayed, select the connection component to reuse its connection details you
have already defined. -
In the Remote directory field, specify
the FTP server directory on which the files and folders will be iterated. In this
example, it is /, which means the root directory
of the FTP server. -
Clear the Move to the current
directory check box. -
Double-click the tIterateToFlow
component to open its Basic settings view. -
Click the
button next to Edit schema to
open the schema dialog box. -
Click the
button to add two String type columns
filename and filepath
that will hold the names and paths of the files to be iterated respectively. When
done, click OK to close the dialog box. -
In the Mapping table, set the values
for the filename and filepath columns. In this example, the global variable ((String)globalMap.get(“tFTPFileList_1_CURRENT_FILE”))
for filename and the global variable ((String)globalMap.get(“tFTPFileList_1_CURRENT_FILEPATH”)) for
filepath.Note that you can fill the values by pressing Ctrl + Space to access the global variables list and then selecting
tFTPFileList_1_CURRENT_FILE and
tFTPFileList_1_CURRENT_FILEPATH from the list. -
Double-click the tLogRow component to
open its Basic settings view, and then select
Table (print values in cells of a table) in the
Mode area for better readability of the
result.
Getting files on the FTP server directory to a local directory
component to get only the text files on the FTP root directory to a local
directory.
-
Double-click the tFTPGet component to
open its Basic settings view. -
Specify the connection details required to access the FTP server. In
this example, select the Use an existing connection
check box and from the Component list drop-down
list displayed, select the connection component to reuse its connection details you
have already defined. -
In the Local directory field, specify
the local directory to which the files and folders will be downloaded. In this
example, it is D:/FtpDownloads. -
In the Remote directory field, specify
the FTP server directory under which the files and folders will be downloaded. In
this example, it is /, which means the root
directory of the FTP server. -
In the Files table, click the
[+] button to add a line and in the Filemask column field, enter *.txt between double quotation marks to get only the text files on
the FTP directory to the local directory.
Closing the connection to the FTP server
component to close the connection to the FTP server.
-
Double-click the tFTPClose component
to open its Basic settings view. -
From the Component list drop-down
list, select the tFTPConnection component that
opens the connection you need to close. In this example, only one tFTPConnection component is used and it is selected by
default.
Executing the Job to list and get files/folders on the FTP directory
the Job for listing and getting files/folders on the FTP directory, you can then execute
the Job and verify the Job execution result.
- Press Ctrl + S to save the Job.
-
Press F6 to execute the Job.
As shown above, the names and paths of the files and folders on the FTP server
root directory are displayed on the console, and only the text files are downloaded
to the specified local directory.