Generation of file previews
Project description
Presentation
This module allows to generate jpeg, pdf, text or html preview for virtually any kind of files. It allows to generate preview for a given page. The context of creation of this module (as an example of use context) was for Tracim, a github project (https://github.com/Tracim/tracim) where users can put file on a repository in order to share it with other users. The only way to find a file was with his name. Hence it was decided to generate previews of the files in order to ease the location of one. Only works on Linux.
Format handled
JPEG |
TEXT |
HTML |
||
---|---|---|---|---|
PNG |
☑ |
|||
JPEG |
☑ |
|||
BMP |
☑ |
|||
GIF |
☑ |
|||
☑ |
||||
Compressed files |
☑ |
☑ |
||
Office files (word, LibreOffice) |
☑ |
☑ |
||
Text |
☑ |
Installation
pip install preview_generator
Requirement
This package uses several libraries :
wand
python-magick
pillow
PyPDF2
These should be automatically installed with the pip install preview_generator command. But if some error occurs quoting one of these library, try to manually install them with a simple pip install …
WARNING! about LibreOffice
If you want to use the conversion from an office file to pdf or jpeg, ensure that LibreOffice is already installed on the computer because the conversion is made by the Libreoffice’s export feature.
LibreOffice’s download page : https://fr.libreoffice.org/download/libreoffice-stable/
Usage
Getting a preview
from PyPreviewGenerator.manager import PreviewManager
manager = PreviewManager(path='/home/user/Pictures/')
path_to_file = manager.get_jpeg_preview(
file_path='/home/user/Pictures/myfile.gif',
height=100,
width=100,
)
print('Preview created at path : ', path_to_file)
The preview manager
preview_manager = PreviewManager(cache_path)
args :
cache_path : a String of the path to the directory where the cache file will be stored
returns :
a PreviewManager Object
The builders
Here is the way it is meant to be used
For Office types into PDF :
preview_manager = PreviewManager(cache_path)
preview = preview_manager.get_pdf_preview(file_path,page=page_id)
-> Will create a preview from an office file into a pdf file
args :
file_path : the String of the path where is the file you want to get the preview
page : the page you want to get. If not mentioned all the pages will be returned
returns :
a FileIO stream of bytes of the pdf preview
For images(GIF, BMP, PNG, JPEG, PDF) into jpeg :
preview_manager = PreviewManager(cache_path)
preview = preview_manager.get_jpeg_preview(file_path,height=1024,width=526)
-> Will create a preview from an image file into a jpeg file of size 1024 * 526
args :
file_path : the String of the path where is the file you want to get the preview
height : height of the preview in pixels
width : width of the preview in pixels. If not mentioned, width will be the same as height
returns :
a FileIO stream of bytes of the jpeg preview
Other conversions :
The principle is the same as above
Zip to text or html : will build a list of files into texte/html inside the json
Office to jpeg : will build the pdf out of the office file and then build the jpeg.
Text to text : mainly just a copy stored in the cache
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
File details
Details for the file PyPreviewGenerator-0.1.12.tar.gz
.
File metadata
- Download URL: PyPreviewGenerator-0.1.12.tar.gz
- Upload date:
- Size: 8.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 986c7e3b6464798178b7ea9cc0dd1e15305b1d235ef7b49c873d3ee37323582b |
|
MD5 | 211846e79291b45a6b4bf01e21e339a4 |
|
BLAKE2b-256 | c518324a8ce6a21f87623f78d83a52417f1fc54909dbd1e3813d0642104cf1c3 |