Python API
FTP
- class RPA.FTP.FTP
FTP library can be used to access an FTP server, and interact with files.
The library is based on Python’s built-in ftplib.
Examples
Robot Framework
*** Settings *** Library RPA.FTP *** Variables *** ${HOST} 127.0.0.1 ${PORT} 27345 ${USER} user ${PASS} 12345 *** Tasks *** List files on the server directory Connect ${HOST} ${PORT} ${USER} ${PASS} @{files} List Files FOR ${file} IN @{files} Log ${file} END
Python
from RPA.FTP import FTP library = FTP() library.connect('127.0.0.1', 27345, 'user', '12345') files = library.list_files() for f in files: print(f)
- ROBOT_LIBRARY_DOC_FORMAT = 'REST'
- ROBOT_LIBRARY_SCOPE = 'GLOBAL'
- abort() bool
Abort a file transfer in progress
- Returns:
true or false based on success or failure
- close() None
Close connection to the server unilaterally
- connect(host: str, port: int = 21, user: str | None = None, password: str | None = None, tls: bool = False, transfer: str = 'passive', keyfile: str | None = None, certfile: str | None = None, timeout: int | None = None, source_address: Tuple[str, int] | None = None) bool
Connect to FTP server
- Parameters:
host – address of the server
port – port of the server, defaults to 21
user – login name, defaults to None
password – login password, defaults to None
tls – connect using TLS support, defaults to False
transfer – mode of the transfer, defaults to “passive”
keyfile – path to private key file
certfile – path to certificate file
timeout – a timeout in seconds for the connection attempt
source_address – socket to bind to as its source address before connecting
- Raises:
AuthenticationException – on authentication error with the server
- Returns:
true if the connnection completes and an error code if it fails
- cwd(dirname: str) bool
Change working directory on the server
- Parameters:
dirname – name of the directory
- Returns:
true or false based on success or failure
- delete(filepath: str) bool
Delete file on the server
- Parameters:
filepath – path to server file
- Returns:
true or false based on success or failure
- download(remotefile: str, localfile: str | None = None) bool
Download file from FTP server
- Parameters:
remotefile – path to remote file on the server
localfile – name of the downloaded file on the local filesystem, if None will have same name as remote file
- Returns:
true or false based on success or failure
- file_size(filepath: str) int
Return byte size of the file on the server
- Parameters:
filepath – path to server file
- Returns:
byte size as an int
- get_welcome_message() str
Get server welcome message
- Returns:
welcome message as a string
- list_files(dirname: str = '') list
List files on the server directory
- Parameters:
dirname – name of the directory
- Returns:
list of files present in the server directory
- mkd(dirname: str) bool
Create a new directory on the server
- Parameters:
dirname – name of the directory
- Returns:
true or false based on success or failure
- pwd() str
Get current working directory on the server
- Returns:
current working directory name as a string
- quit() None
Send QUIT command to the server and close connection
- rename(fromname: str, toname: str) bool
Rename file on the server
- Parameters:
fromname – current name of the file
toname – new name for the file
- Returns:
true or false based on success or failure
- rmd(dirname: str) bool
Remove directory on the server
- Parameters:
dirname – name of the directory
- Returns:
true or false based on success or failure
- send_command(command: str) bool
Execute command on the server
List of FTP commands: https://en.wikipedia.org/wiki/List_of_FTP_commands
- Parameters:
command – name of the command to send
- Returns:
true or false based on success or failure
- set_ascii_mode() bool
Set transfer mode to ASCII
- Returns:
true or false based on success or failure
- set_binary_mode() bool
Set transfer mode to BINARY
- Returns:
true or false based on success or failure
- set_debug_level(level: int = 0) bool
Set debug level for the library
- Parameters:
level – integer value of debug level, defaults to 0
- Returns:
true or false based on success or failure
0 - no debugging output 1 - moderate amount of debugging 2+ - higher amount of debugging
- upload(localfile: str, remotefile: str) bool
Upload file to FTP server
- Parameters:
localfile – path to file to upload
remotefile – name of uploaded file in the server
- Returns:
true or false based on success or failure