Skip to main content

Classes for creating and wrapping file-like objects

Project description

The filelike module takes care of the groundwork for implementing and handling file-like objects that implement a rich file-like interface, including reading, writing, and iteration. It also provides a number of useful classes built on top of this functionality.

The main class is FileLikeBase, which implements the entire file-like interface (currently minus seek() and tell()) on top of primitive _read() and _write() methods. Subclasses may implement either or both of these methods to obtain all the higher-level file behaviors.

Two methods are provided for when code expects to deal with file-like objects:

  • is_filelike(obj): checks that an object is file-like

  • to_filelike(obj): wraps a variety of objects in a file-like interface

The “wrappers” subpackage contains a collection of useful classes built on top of this framework. These include:

  • TransFile: pass file contents through an arbitrary translation

    function (e.g. compression, encryption, …)

  • FixedBlockSizeFile: ensure all read/write requests are aligned with

    a given blocksize

  • DecryptFile: on-the-fly reading and writing to an encrypted file

    (using PEP272 cipher API)

As an example of the type of thing this module is designed to achieve, here’s an example of using the DecryptFile class to transparently access an encrypted file:

# Create the decryption key from Crypto.Cipher import DES cipher = DES.new(‘abcdefgh’,DES.MODE_ECB) # Open the encrypted file from filelike.wrappers import DecryptFile f = DecryptFile(file(“some_encrypted_file.bin”,”r”),cipher)

The object in <f> now behaves as a file-like object, transparently decrypting the file on-the-fly as it is read.

The “pipeline” subpackage contains facilities for composing these wrappers in the form of a unix pipeline. In this example, <f> will read the first five lines of an encrypted file:

from filelike.pipeline import DecryptFile, Head f = file(“some_encrypted_file.bin”) > DecryptFile(cipher) | Head(lines=5)

Finally, the function filelike.open() mirrors the standard file opening function but tries to be clever about accessing the file - URLs are automatically fetched using urllib2, compressed files and decompressed on the fly, and so-forth.

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

filelike-0.2.1.tar.gz (30.0 kB view details)

Uploaded Source

Built Distribution

filelike-0.2.1-py2.4.egg (42.3 kB view details)

Uploaded Source

File details

Details for the file filelike-0.2.1.tar.gz.

File metadata

  • Download URL: filelike-0.2.1.tar.gz
  • Upload date:
  • Size: 30.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for filelike-0.2.1.tar.gz
Algorithm Hash digest
SHA256 b602752bc128430bcde5c4621996a644a7c3b8b350c0625d5a4bf5136accc614
MD5 6a3f53289723d19f3f1ba7db92ee16cc
BLAKE2b-256 4bb7bec8cc5f9bfb97d9988b29b128347713ff0d6927db2b6d5351f1e4a019cc

See more details on using hashes here.

File details

Details for the file filelike-0.2.1-py2.4.egg.

File metadata

  • Download URL: filelike-0.2.1-py2.4.egg
  • Upload date:
  • Size: 42.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for filelike-0.2.1-py2.4.egg
Algorithm Hash digest
SHA256 9961242bcd78227f51ae5dcd8a52153d7124bfdf5ef6bd1445e4c3919be585c5
MD5 7df3723dfa1a8994e6b3d44a458235b7
BLAKE2b-256 50cbd00869fd1b1f3a882b49f8012bcd9bd6dc7733976599cc036cfdb5a79121

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