Ymodem Python3 implementation
Project description
Fork of the YMODEM project by alexwoo1900 Now available on PyPi, also now it can be used as cli tool for Serial ports The YMODEM project is based on XMODEM implementation written by tehmaze. It is also compatible with XMODEM mode.
Installation
pip install ymodem
Usage
CLI TOOL
# To get help
ymodem -h
# or
python -m ymodem -h
Sending a batch of files
ymodem send ./file.bin ./file2.bin -p COM4 -b 115200
# or
python -m ymodem send ./file.bin ./file2.bin -p COM4 -b 115200
Receive a file
ymodem recv ./ -p COM4 -b 115200
# or
python -m ymodem recv ./ -p COM4 -b 115200
Demo
Test the sending and receiving functions
If you want to run the test sample, please do the following:
- use virtual serial port tool to generate COM1 and COM2 that can communicate
- run the FileReceiver.py and FileSender.py on the command line
The specific transmission process is shown in the following figure:
Interact with SecureCRT
Interact with SecureCRT as sender
Interact with SecureCRT as Finder
Quick start
from ymodem.Socket import ModemSocket
# define read
def read(size, timeout = 3):
# implementation
# define write
def write(data, timeout = 3):
# implementation
# create socket
cli = ModemSocket(read, write)
# send multi files
cli.send([file_path1, file_path2, file_path3 ...])
# receive multi files
cli.recv(folder_path)
For more detailed usage, please refer to the demo/FileReceiver.py and demo/FileSender.py files.
API
Create MODEM Object
def __init__(self,
read: Callable[[int, Optional[float]], Any],
write: Callable[[Union[bytes, bytearray], Optional[float]], Any],
protocol_type: int = ProtocolType.YMODEM,
protocol_type_options: List[str] = [],
packet_size: int = 1024,
style_id: int = _psm.get_available_styles()[0]):
- protocol_type: Protocol type, see Protocol.py
- protocol_type_options: such as g representing the YMODEM-G in the YMODEM protocol.
- packet_size: The size of a single packet, 128/1024 bytes, may be adjusted depending on the protocol style
- style_id: Protocol style, different styles have different support for functional features
Send files
def send(self,
paths: List[str],
callback: Optional[Callable[[int, str, int, int], None]] = None
) -> bool:
-
callback: callback function. see below.
Parameter Description task index index of current task task (file) name name of the file total packets number of packets plan to send success packets number of packets successfully sent
Receive files
def recv(self,
path: str,
callback: Optional[Callable[[int, str, int, int], None]] = None
) -> bool:
- callback: callback function. Same as the callback of send().
Debug
If you want to output debugging information, set the log level to DEBUG.
logging.basicConfig(level=logging.DEBUG, format='%(message)s')
Changelog
v1.5.1b1 (2024/02/03)
- Added additional options to cli tool
v1.5.1b0 (2024/02/03)
- Added cli tool to iteract with YMODEM via Serial bus
- Fix of transaction end logic in send()
v1.5 (2023/05/20 11:00 +00:00)
- Rewritten send() and recv()
- Support YMODEM-G. The success rate of YMODEM-G based on pyserial depends on the user's OS, and after testing, the success rate is very low without any delay.
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ymodem-1.5.1b2.tar.gz
.
File metadata
- Download URL: ymodem-1.5.1b2.tar.gz
- Upload date:
- Size: 22.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 691c04a0940a70f7944c599f19d0fb8ef75c88fac1ed01b7b6e92eaaba3a11a2 |
|
MD5 | e96d76fbdc46ef20d46bc915e8612f30 |
|
BLAKE2b-256 | eedc3e45f9859f6d13c0fa8c242eedbc5e10c45f135c6a8041a0655ae7b5e995 |
File details
Details for the file ymodem-1.5.1b2-py3-none-any.whl
.
File metadata
- Download URL: ymodem-1.5.1b2-py3-none-any.whl
- Upload date:
- Size: 21.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 803783f9138bc03f90234a68af1a5871dec3b8d93355660379a639e6d4e0ec02 |
|
MD5 | 335578de726ac8ee29f6e61b662cab32 |
|
BLAKE2b-256 | 4e63563c01c34220b08f7117f43b0ee9dd683a10db66e30a8c6592f73b800cdf |