Skip to main content

A universal command line tool for compression and decompression

Project description

A universal command line tool for compression and decompression

  • Supports more normal compressed file formats than I can remember, like Zip, Tar, Gzip, Bzip2, 7-Zip, Rar, Rar.bz2, Tar.gz and so on.
  • Supports split volumn compressed file for certain formats, like Tar.bz2, Tar.bz, Tar.gz, Tgz, Tar.7z, Tar, 7z, Zip, Rar.
  • Supports decompress normal and split volumn compressed file in the same command. In split volumn mode, any part of the input split file can be decompress correctly.
  • Support for automatic creation of target folders. If you have a path with spaces in it, it will handle that too.
  • The decompress engine itself and command-line tool has only been tested in Linux environment so far.

Install Cli

pip install allz

Command Description

allz -d -q -f src_path -o dest_path
  • src_path      The input source path.

  • dest_path    The output destination path.

  • -d        Decompress normal or split compressed files.

  • -q        Run in quiet mode.

  • -f        Always overwrite files when a file to be unpacked already exists on disk. By default, the program will skips the file.

  • -p        Output regular expressions for both regular compressed files and slice compressed files successively: the first line is for the normal compressed file, the second line is for the split volumn compressed file.

    • -p --only-normal    Output regular matching expressions for normal compressed files only.
    • -p --only-split      Output regular expressions for split volumn compressed files only.

Available options:

  • --output-directory (-o)     The directory to write the contents of the archive to. Defaults to the current directory.

Examples

Suppose we now have a normal compressed file MNIST.7z and two split volumn compressed files MNIST.tar.7z.001, MNIST.tar.7z.002.

1. View the version

allz --version

2. View the help

allz -h

or

allz --help

3. Check which types are supported for decompression in your local environment

allz check

4. Decompress the normal file MNIST.7z to current directory

allz -d MNIST.7z

In default, if the compressed file have already decompress before, it will skip the same file. You can use option -f to overwrite the files.

allz -d -f MNIST.7z

You can also mask screen log output by use option -q.

allz -d -q MNIST.7z

5. Decompress the normal file MNIST.7z to the specified directory by use option -o

allz -d MNIST.7z -o /tmp

You can also use the relative destination path.

allz -d MNIST.7z -o ..

6. Decompress the split volumn file MNIST.tar.7z.001

allz -d MNIST.tar.7z.001 

Decompress the split volumn file to specified directory by use option -o.

allz -d MNIST.tar.7z.001 -o /tmp

7.Handle the path with space in it

Methods of using escapes

allz -d 20220101\ todo/MNIST.7z -o /tmp/20220101\ done/MNIST.7z

Methods of using quotation marks

allz -d "20220101 todo/MNIST.7z" -o "/tmp/20220101 done/MNIST.7z"

8. Decompress the file into a recurvise destination directory

It will automatically create folders that do not exist.

allz -d MNIST.7z -o /tmp/today/fruit/apple/

SDK

1. Function get_compressed_files_classify_lst

  • Source code: allz/libs/file_type_tester

  • FileTypeTester.get_compressed_files_classify_lst(file_lst)

    • Return a nested list which will sort the input file list into multiple common or split volumn compressed file lists. The input parameter file_lst is a list of files in the same hierarchical directory. The list can be a file name, a full path or a relative path name. Function only processes compressed files, including normal compressed files and split volumn compressed files, ignoring the processing of normal files.
  • A short usage example:

      from allz.libs.file_type_tester import FileTypeTester
    
      file_lst = ["MNIST.tar.0000", "MNIST.tar.0001", "MNIST.tar.0002", "MNIST.tar.0003", "MNIST.tar.0004", "MNIST.tar.7z.001", "MNIST.tar.7z.002", "MNIST.part1.rar", "MNIST.part2.rar", "MNIST.part3.rar", "MNIST.part4.rar", "MNIST.7z.001", "MNIST.7z.002", "123.rar", "abc.zip", "abc", "000", "0000.tar", "02287.txt"]
    
      tester = FileTypeTester() 
      res_lst = tester.get_compressed_files_classify_lst(file_lst)
      print(res_lst)
    

    Output:
    [['/home/work/srccode/github/allz/allz/libs/MNIST.tar.0000', '/home/work/srccode/github/allz/allz/libs/MNIST.tar.0002', '/home/work/srccode/github/allz/allz/libs/MNIST.tar.0004', '/home/work/srccode/github/allz/allz/libs/MNIST.tar.0003', '/home/work/srccode/github/allz/allz/libs/MNIST.tar.0001'], ['/home/work/srccode/github/allz/allz/libs/MNIST.tar.7z.002', '/home/work/srccode/github/allz/allz/libs/MNIST.tar.7z.001'], ['/home/work/srccode/github/allz/allz/libs/MNIST.part4.rar', '/home/work/srccode/github/allz/allz/libs/MNIST.part1.rar', '/home/work/srccode/github/allz/allz/libs/MNIST.part2.rar', '/home/work/srccode/github/allz/allz/libs/MNIST.part3.rar'], ['/home/work/srccode/github/allz/allz/libs/MNIST.7z.001', '/home/work/srccode/github/allz/allz/libs/MNIST.7z.002'], ['/home/work/srccode/github/allz/allz/libs/123.rar'], ['/home/work/srccode/github/allz/allz/libs/000.tar']]

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

allz-0.1.4.tar.gz (14.2 kB view details)

Uploaded Source

Built Distribution

allz-0.1.4-py3-none-any.whl (18.9 kB view details)

Uploaded Python 3

File details

Details for the file allz-0.1.4.tar.gz.

File metadata

  • Download URL: allz-0.1.4.tar.gz
  • Upload date:
  • Size: 14.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.13

File hashes

Hashes for allz-0.1.4.tar.gz
Algorithm Hash digest
SHA256 469b176689324e0022737d5db1f5657ec8b6b5aff5d9c2461ee5452101151ef3
MD5 662118a69905e7326906846bef917741
BLAKE2b-256 3fba7b0ec1168d1227570914f328066e4d9bbdafc9b569819818c5b8e59b658f

See more details on using hashes here.

File details

Details for the file allz-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: allz-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 18.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.13

File hashes

Hashes for allz-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 ba0f2625218b4968ed0254ffb0e219d8e8ae2774d78510595a59a2e45adc92ad
MD5 ffb4e20757c62734331b1b3451a30eca
BLAKE2b-256 6542b4a3a1a7f46547a2f2042e6faa43f610c0a90eab8d3679e48b176174a7a6

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