Skip to main content

Easy usage of FTP operation

Project description

NOTE: THIS PACKAGE IS IN TEST VERSION YET.

EasyFTP

EasyFTP is a Python library that simplifies the process of interacting with FTP (File Transfer Protocol) servers. With EasyFTP, you can easily upload, download, delete, and list files and directories on remote FTP servers using a simple and intuitive interface.

Features

  • Connect to FTP servers with ease.
  • Upload files and directories to remote servers.
  • Download files and directories from remote servers.
  • Delete files and directories on remote servers.
  • List files and directories on remote servers.
  • (not implemented) Support for both FTP and secure FTP (FTPS).

Installation

You can install EasyFTP via pip:

pip install EasyFtp

Usage

Structure of the directory /example used here :

/examples
├── dir1
│   ├── a.png
│   ├── b.png
│   └── c.jpg
├── dir2
│   └── subdir-a
│       ├── random.key
│       └── randon.key
├── dir3
│   ├── some.binary
│   └── some.binary.X
├── example.py
└── example.py2
  • Establishing connection
from EasyFTP import EasyFTP as easyftp

with easyftp.EasyFTP() as session:
	session.connect("192.168.1.1", 21, "admin", "12345678", timeout = 30)
	# Change it to your option, and timeout is not necessary.
  • Listing files on remote directory
from EasyFTP import EasyFTP as easyftp

with easyftp.EasyFTP() as session:
	session.connect("192.168.1.1", 21, "admin", "12345678", timeout = 30)
	# Change it to your option, and timeout is not necessary.
	l = session.ls("/examples")
	# Directory argument is not necessary;
	# It will print structure of current directory when there is no argument.
	print(l)

It will print, for example: ["dir1", "dir2", "dir3", "example.py", "example.py2"]

  • Changing directory in remote (and printing current working directory)
from EasyFTP import EasyFTP as easyftp

with easyftp.EasyFTP() as session:
	session.connect("192.168.1.1", 21, "admin", "12345678", timeout = 30)
	# Change it to your option, and timeout is not necessary.
	
	session.cd("/examples")
	# This will change your directory to /examples.
	# NOTE: Relative path is not tested yet.

	print(session.cd())
	# This will print "/examples", which is your current working directory.
	# It does this when there is no argument passed to it.

	print(session.pwd())
	# It works like session.cd().
  • Downloading specific file(s) from remote
from EasyFTP import EasyFTP as easyftp

with easyftp.EasyFTP() as session:
	session.connect("192.168.1.1", 21, "admin", "12345678", timeout = 30)
	# Change it to your option, and timeout is not necessary.

	# Low-level example.
	# This works by reading file on remote and retrieve it as string,
	# and then write it to your desired file manually.
	# This will raise FTPError if you don't have permission to
	# read files, write permission to your local file,
	# or error(s) not described here. It can be anything.
	content = session.read("/examples/example.py")
	with open("./example.py", encoding = "utf-8") as f:
		f.write(content)

	# This will change your directory to /examples.
	# So you won't need to specify path to file IF IT EXISTS IN THE PATH.
	# NOTE: Relative path is not tested yet.
	session.cd("/examples")

	# High-level example.
	# This works by reading file on remote and retrieve it as file,
	# which will be saved to specified file(s)/path which local_path variable indicates.
	# This can raise error, too. Read them carefully if it happened.
	# TODO : Return whether or not it has succeeded.

	# Downloading one file.
	session.download("example.py", "example.py")

	# TODO : Downloading multiple files using wildcard(s).
	# session.download("ex*.py*", ".")

	# Downloading a directory.
	# local_file MUST indicate a directory to do this.
	# The subdirectory(subdirectories) in the directory will be downloaded too.
	# TODO : Add EasyFTP.filter object to filter files to be downloaded.
	session.download("dir2", ".")
  • Uploading file to remote
from EasyFTP import EasyFTP as easyftp

with easyftp.EasyFTP() as session:
	session.connect("192.168.1.1", 21, "admin", "12345678", timeout = 30)
	# Change it to your option, and timeout is not necessary.

	# Low-level example.
	# This works by converting encoded string it as BytesIO,
	# and then write it to your desired remote file manually.
	# This will raise FTPError if you don't have permission to
	# read files, write permission to your local/remote file,
	# or error(s) not described here. It can be anything.
	session.write("/example/example.py3", "print('hello world!')")

	# This will change your directory to /examples.
	# So you won't need to specify path to file IF IT EXISTS IN THE PATH.
	# NOTE: Relative path is not tested yet.
	session.cd("/examples")

	# High-level example.
	# This works by reading file on local and retrieve it as binary,
	# which will be saved to specified file(s)/path which remote_path variable indicates.
	# This can raise error, too. Read them carefully if it happened.
	# TODO : Return whether or not it has succeeded.

	# Uploading one file.
	session.upload("example.py4", "example.py4")

	# TODO : Uploading multiple files using wildcard(s).
	# session.download("ex*.py*", ".")

	# Uploading a directory.
	# remote_file MUST indicate a directory to do this.
	# The subdirectory(subdirectories) in the directory will be uploaded too.
	# TODO : Add EasyFTP.filter object to filter files to be uploaded.
	session.download("./new_dir", ".")
  • Making directory
from EasyFTP import EasyFTP as easyftp

with easyftp.EasyFTP() as session:
	session.connect("192.168.1.1", 21, "admin", "12345678", timeout = 30)
	# Change it to your option, and timeout is not necessary.
	
	# This will create directory on /examples .
	session.mkdir("/examples/new_dir2")

	# This will change your directory to /examples.
	# NOTE: Relative path is not tested yet.
	session.cd("/examples")

	# This will create directory on your current directory.
	session.mkdir("/examples/new_dir3")

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

EasyFTP-0.0.10b0.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

EasyFTP-0.0.10b0-py3-none-any.whl (5.2 kB view details)

Uploaded Python 3

File details

Details for the file EasyFTP-0.0.10b0.tar.gz.

File metadata

  • Download URL: EasyFTP-0.0.10b0.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.1

File hashes

Hashes for EasyFTP-0.0.10b0.tar.gz
Algorithm Hash digest
SHA256 7aea436f8bb53518a37c51ef1c9f9d6b71a5ccdda7d95295115b4d61c914ae6e
MD5 e288fef14179f18d4fae5cf05f8e6ac9
BLAKE2b-256 a509e0c6f8c0adeb9857b866a7cc630c97797aab3cf8b749fe68e2ca20097a3c

See more details on using hashes here.

File details

Details for the file EasyFTP-0.0.10b0-py3-none-any.whl.

File metadata

  • Download URL: EasyFTP-0.0.10b0-py3-none-any.whl
  • Upload date:
  • Size: 5.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.1

File hashes

Hashes for EasyFTP-0.0.10b0-py3-none-any.whl
Algorithm Hash digest
SHA256 0c9a94a28769ad367ed89503425fe8ba8664d4684e7502ad5d8aa08100201a4f
MD5 da0ad510c487f1fb15d6a2dfd44caf1a
BLAKE2b-256 74cbce08935fc65a50da587e395738bac40904fc1d3b38a2926e5ac5b33d053d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page