Python API

Archive

class RPA.Archive.Archive

Archive is a library for operating with ZIP and TAR packages.

Examples

*** Settings ***
Library  RPA.Archive

*** Tasks ***
Creating a ZIP archive
   Archive Folder With ZIP   ${CURDIR}${/}tasks  tasks.zip   recursive=True  include=*.robot  exclude=/.*
   @{files}                  List Archive             tasks.zip
   FOR  ${file}  IN  ${files}
      Log  ${file}
   END
   Add To Archive            .${/}..${/}missing.robot  tasks.zip
   &{info}                   Get Archive Info
from RPA.Archive import Archive

lib = Archive()
lib.archive_folder_with_tar('./tasks', 'tasks.tar', recursive=True)
files = lib.list_archive('tasks.tar')
for file in files:
   print(file)
ROBOT_LIBRARY_DOC_FORMAT = 'REST'
ROBOT_LIBRARY_SCOPE = 'GLOBAL'
add_to_archive(files: List | str, archive_name: str, folder: str | None = None) None

Add file(s) to the archive

Parameters:
  • files – name of the file, or list of files, to add

  • archive_name – filename of the archive

  • folder – name of the folder where the file will be added, relative path within the archive

Returns:

None

This keyword adds a file or list of files into an existing archive. Files can be added to archive structure with relative path using argument folder.

Example:

Add To Archive  extrafile.txt  myfiles.zip
Add To Archive  stat.png       archive.tar.gz  images
@{files}        Create List    filename1.txt   filename2.txt
Add To Archive  ${files}       files.tar
archive_folder_with_tar(folder: str, archive_name: str, recursive: bool = False, include: str | None = None, exclude: str | None = None) None

Create a tar/tar.gz archive of a folder

Parameters:
  • folder – name of the folder to archive

  • archive_name – filename of the archive

  • recursive – should sub directories be included, default is False

  • include – define file pattern to include in the package, default is None which means all files are included

  • exclude – define file pattern to exclude from the package, default is None

Returns:

None

This keyword creates an TAR or TAR.GZ archive of a local folder. Type of archive is determined by the file extension. By default subdirectories are not included, but they can included using recursive argument.

To include only certain files, like TXT files, the argument include can be used. Similarly to exclude certain file, like dotfiles, the argument exclude can be used.

Example:

Archive Folder With TAR  ${CURDIR}${/}documents  documents.tar
Archive Folder With TAR  ${CURDIR}${/}tasks      tasks.tar.gz   include=*.robot
Archive Folder With TAR  ${CURDIR}${/}tasks      tasks.tar      exclude=/.*
Archive Folder With TAR  ${CURDIR}${/}documents  documents.tar  recursive=True
archive_folder_with_zip(folder: str, archive_name: str, recursive: bool = False, include: str | None = None, exclude: str | None = None, compression: str = 'stored') None

Create a zip archive of a folder

Parameters:
  • folder – name of the folder to archive

  • archive_name – filename of the archive

  • recursive – should sub directories be included, default is False

  • include – define file pattern to include in the package, default is None which means all files are included

  • exclude – define file pattern to exclude from the package, default is None

  • compression – type of package compression method, default is “stored”

Returns:

None

This keyword creates an ZIP archive of a local folder. By default subdirectories are not included, but they can be included using the recursive argument.

To include only certain files, like TXT files, the argument include can be used. Similarly to exclude certain files, like dotfiles, the argument exclude can be used.

Compression methods:

  • stored, default

  • deflated

  • bzip2

  • lzma

Example:

Archive Folder With Zip  ${CURDIR}${/}documents  mydocs.zip
Archive Folder With Zip  ${CURDIR}${/}tasks      robottasks.zip   include=*.robot
Archive Folder With Zip  ${CURDIR}${/}tasks      no_dotfiles.zip  exclude=/.*
Archive Folder With Zip  ${CURDIR}${/}documents  documents.zip    recursive=True
Archive Folder With Zip  ${CURDIR}               packagelzma.zip  compression=lzma
Archive Folder With Zip  ${CURDIR}               bzipped.zip      compression=bzip2
from RPA.Archive import Archive

lib = Archive()
lib.archive_folder_with_zip('./documents', 'mydocs.zip')
lib.archive_folder_with_zip('./tasks', 'robottasks.zip', include='*.robot')
lib.archive_folder_with_zip('./tasks', 'no_dotfiles.zip', exclude='/.*')
lib.archive_folder_with_zip('./documents', 'documents.zip', recursive=True)
lib.archive_folder_with_zip('./', 'packagelzma.zip', compression='lzma')
lib.archive_folder_with_zip('./', 'bzipped.zip', compression='bzip2')
extract_archive(archive_name: str, path: str | None = None, members: List | str | None = None) None

Extract files from archive into local directory

Parameters:
  • archive_name – filename of the archive

  • path – filepath to extract file into, default is current working directory

  • members – list of files to extract from archive, by default all files in archive are extracted

Returns:

None

This keyword supports extracting files from zip, tar and tar.gz archives.

By default file is extracted into current working directory, but path argument can be set to define extraction path.

Example:

Extract Archive    myfiles.zip   ${CURDIR}${/}extracted
@{files}           Create List   filename1.txt    filename2.txt
Extract Archive    archive.tar   C:${/}myfiles${/}  ${files}
extract_file_from_archive(filename: str, archive_name: str, path: str | None = None) None

Extract a file from archive into local directory

Parameters:
  • filename – name of the file to extract

  • archive_name – filename of the archive

  • path – filepath to extract file into, default is current working directory

Returns:

None

This keyword supports extracting a file from zip, tar and tar.gz archives.

By default file is extracted into current working directory, but path argument can be set to define extraction path.

Example:

Extract File From Archive    extrafile.txt   myfiles.zip
Extract File From Archive    background.png  images.tar.gz  ${CURDIR}${/}extracted
get_archive_info(archive_name: str) dict

Get information about the archive

Parameters:

archive_name – filename of the archive

Returns:

dictionary variable containing the keys filename, filemode, size, mtime, modified

Returns following file attributes in a dictionary:

  • filename

  • filemode

  • size

  • mtime

  • last modification time in format %d.%m.%Y %H:%M:%S

Example:

&{archiveinfo}   Get Archive Info    myfiles.zip
list_archive(archive_name: str) list

List files in an archive

Parameters:

archive_name – filename of the archive

Returns:

dictionary variable containing the keys name, size, mtime, modified

Returns list of files, where each file in a list is a dictionary with following attributes:

  • name

  • size

  • mtime

  • last modification time in format %d.%m.%Y %H:%M:%S

Example:

@{files}   List Archive    myfiles.zip
FOR  ${file}  IN   ${files}
    Log  ${file}[filename]
    Log  ${file}[size]
    Log  ${file}[mtime]
END