fttlib


Namefttlib JSON
Version 1.1.7 PyPI version JSON
download
home_pagehttps://github.com/brondavies/filetypetranslator
SummaryA library of helper methods for your Python project to get mime types and general file category
upload_time2024-09-19 21:21:27
maintainerNone
docs_urlNone
authorBron Davies
requires_pythonNone
licenseNone
keywords file type mime mapping path inspection upload download email ftt
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # ![FTT Logo](https://raw.githubusercontent.com/brondavies/filetypetranslator/master/ftt-icon.png) File Type Translator (FTT)

A library of helper methods for your Python project to get [mime types](https://en.wikipedia.org/wiki/Media_type) and general file category

# Releases
Available as a [pypi package](https://pypi.org/packages/fttlib)
#### 1.1.7 - Updated sources, optimized generated code to be smaller and to be easier to diff future versions
#### 1.1.5 - Updated sources, adds many modern file types and updates/eliminates some legacy mime types
#### 1.1.3 - Updated sources, Notably the mime type for .js is now text/javascript instead of application/javascript according to the [IANA standard specification](https://www.iana.org/assignments/media-types/application/javascript)
#### 1.1.2 - Initial python release

# Examples

#### Install

```sh
pip install fttlib
```

#### Import the library

```python
from FTTLib import FTT
```

####  When you need to know the mime type of a file based on its extension.

```python
mimeType = FTT.getMimeType("Path/To/My/File.doc")
print(mimeType)

mimeType = FTT.getMimeType("Path/To/My/File.docx")
print(mimeType)

>  application/msword
>  application/vnd.openxmlformats-officedocument.wordprocessingml.document
```

####  When you need to know the file type category of a file based on its extension.

```python
category = FTT.getFileCategory("Path/To/My/File.docx")
print(category)

category = FTT.getFileCategory("Path/To/My/File.jpg")
print(category)

>  FileCategory.Document
>  FileCategory.Image
```

####  When you need to know the preferred file extension for a file based on its mime type.

```python
extensions = FTT.getMimeTypeFileExtensions("text/csv")
print(extensions[0])

>  csv
```

# Design

This library is designed along the following tenets:

* No external dependencies
* No file system access
* Small memory footprint
* Simple static methods (no extension methods and no instantiatable classes)
* Case-insensitive
* Portable - works in applications targeting any runtime

# File Categories

File media types are broken down into relatively few categories.  Sub-categories may be considered in a future release according to information on [Wikipedia](https://en.wikipedia.org/wiki/List_of_file_formats)  Here are the guidelines that determine a file's category

* Archive: any file that can be extracted into several files
* Audio: any file that can only contain an audio stream
* Binary: any file that is unclassified or does not have a text representation
* Code: any file that contains instructions that are compilable or machine-readable
* Document: any file that is designed for conveying structured information between people
* Image: any file that can only contain a single image or series of images
* PDF: any file that is considered a document archive format
* Presentation: any file that is designed for electronic presentations consisting of a series of separate pages or slides
* Spreadsheet: any file in which data is arranged in rows and columns and can be manipulated and used in calculations
* Text: any file that is not classified under another category and is not binary
* Video: any file that is designed to be a container for a video stream

# Known Limitations

* Even though a mime type to file extension mapping is not necessarily one-to-one, the most common should be returned by the library
* This library does not provide file sniffing capabilities - in other words, if you have a file and you want to verify the contents are of a specific type, look elsewhere. FTT only uses the file name with an extension.  That capability may be added in a future release.
* The only file categories presently considered are Archive, Audio, Binary, Code, Document, Image, PDF, Presentation, Spreadsheet, Text, and Video.  Binary is the default if there is no match in the database.

# Sources

While it is unrealistic to expect this library to provide a comprehensive list with *all* the file types the world has to offer, it would be nice if we could get close.  Generally, if the file type is even remotely common, it is listed in one of the sources.  You can [submit a bug report](https://github.com/brondavies/filetypetranslator/issues/new) for a file type that is missing or that you think should be added.  You will have to include a reputable source as well.

### Information sources for this library are provided through the following and in order of preference:

1. http://www.iana.org/assignments/media-types/media-types.xhtml
1. https://gitlab.freedesktop.org/xdg/shared-mime-info
1. https://cdn.rawgit.com/jshttp/mime-db/master/db.json
1. http://www.file-extensions.org/



            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/brondavies/filetypetranslator",
    "name": "fttlib",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "file, type, mime, mapping, path, inspection, upload, download, email, FTT",
    "author": "Bron Davies",
    "author_email": "bron@brontech.com",
    "download_url": "https://files.pythonhosted.org/packages/62/8d/adfd1cd1f9bb4e36009e436b79b35ea97a0472d5298bdb572d2262562349/fttlib-1.1.7.tar.gz",
    "platform": null,
    "description": "# ![FTT Logo](https://raw.githubusercontent.com/brondavies/filetypetranslator/master/ftt-icon.png) File Type Translator (FTT)\n\nA library of helper methods for your Python project to get [mime types](https://en.wikipedia.org/wiki/Media_type) and general file category\n\n# Releases\nAvailable as a [pypi package](https://pypi.org/packages/fttlib)\n#### 1.1.7 - Updated sources, optimized generated code to be smaller and to be easier to diff future versions\n#### 1.1.5 - Updated sources, adds many modern file types and updates/eliminates some legacy mime types\n#### 1.1.3 - Updated sources, Notably the mime type for .js is now text/javascript instead of application/javascript according to the [IANA standard specification](https://www.iana.org/assignments/media-types/application/javascript)\n#### 1.1.2 - Initial python release\n\n# Examples\n\n#### Install\n\n```sh\npip install fttlib\n```\n\n#### Import the library\n\n```python\nfrom FTTLib import FTT\n```\n\n####  When you need to know the mime type of a file based on its extension.\n\n```python\nmimeType = FTT.getMimeType(\"Path/To/My/File.doc\")\nprint(mimeType)\n\nmimeType = FTT.getMimeType(\"Path/To/My/File.docx\")\nprint(mimeType)\n\n>  application/msword\n>  application/vnd.openxmlformats-officedocument.wordprocessingml.document\n```\n\n####  When you need to know the file type category of a file based on its extension.\n\n```python\ncategory = FTT.getFileCategory(\"Path/To/My/File.docx\")\nprint(category)\n\ncategory = FTT.getFileCategory(\"Path/To/My/File.jpg\")\nprint(category)\n\n>  FileCategory.Document\n>  FileCategory.Image\n```\n\n####  When you need to know the preferred file extension for a file based on its mime type.\n\n```python\nextensions = FTT.getMimeTypeFileExtensions(\"text/csv\")\nprint(extensions[0])\n\n>  csv\n```\n\n# Design\n\nThis library is designed along the following tenets:\n\n* No external dependencies\n* No file system access\n* Small memory footprint\n* Simple static methods (no extension methods and no instantiatable classes)\n* Case-insensitive\n* Portable - works in applications targeting any runtime\n\n# File Categories\n\nFile media types are broken down into relatively few categories.  Sub-categories may be considered in a future release according to information on [Wikipedia](https://en.wikipedia.org/wiki/List_of_file_formats)  Here are the guidelines that determine a file's category\n\n* Archive: any file that can be extracted into several files\n* Audio: any file that can only contain an audio stream\n* Binary: any file that is unclassified or does not have a text representation\n* Code: any file that contains instructions that are compilable or machine-readable\n* Document: any file that is designed for conveying structured information between people\n* Image: any file that can only contain a single image or series of images\n* PDF: any file that is considered a document archive format\n* Presentation: any file that is designed for electronic presentations consisting of a series of separate pages or slides\n* Spreadsheet: any file in which data is arranged in rows and columns and can be manipulated and used in calculations\n* Text: any file that is not classified under another category and is not binary\n* Video: any file that is designed to be a container for a video stream\n\n# Known Limitations\n\n* Even though a mime type to file extension mapping is not necessarily one-to-one, the most common should be returned by the library\n* This library does not provide file sniffing capabilities - in other words, if you have a file and you want to verify the contents are of a specific type, look elsewhere. FTT only uses the file name with an extension.  That capability may be added in a future release.\n* The only file categories presently considered are Archive, Audio, Binary, Code, Document, Image, PDF, Presentation, Spreadsheet, Text, and Video.  Binary is the default if there is no match in the database.\n\n# Sources\n\nWhile it is unrealistic to expect this library to provide a comprehensive list with *all* the file types the world has to offer, it would be nice if we could get close.  Generally, if the file type is even remotely common, it is listed in one of the sources.  You can [submit a bug report](https://github.com/brondavies/filetypetranslator/issues/new) for a file type that is missing or that you think should be added.  You will have to include a reputable source as well.\n\n### Information sources for this library are provided through the following and in order of preference:\n\n1. http://www.iana.org/assignments/media-types/media-types.xhtml\n1. https://gitlab.freedesktop.org/xdg/shared-mime-info\n1. https://cdn.rawgit.com/jshttp/mime-db/master/db.json\n1. http://www.file-extensions.org/\n\n\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "A library of helper methods for your Python project to get mime types and general file category",
    "version": "1.1.7",
    "project_urls": {
        "Homepage": "https://github.com/brondavies/filetypetranslator"
    },
    "split_keywords": [
        "file",
        " type",
        " mime",
        " mapping",
        " path",
        " inspection",
        " upload",
        " download",
        " email",
        " ftt"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e18778806b0e39633d552b322c09b04b121396b2751af92d02682c5d7c95c891",
                "md5": "f374dbf3a62f174191ffb466180c6d8d",
                "sha256": "c111f07d0e6997a4f74fc272e04bc350d91b3e46e004e2748822cff2fe3b3dbe"
            },
            "downloads": -1,
            "filename": "fttlib-1.1.7-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "f374dbf3a62f174191ffb466180c6d8d",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 61309,
            "upload_time": "2024-09-19T21:21:26",
            "upload_time_iso_8601": "2024-09-19T21:21:26.012513Z",
            "url": "https://files.pythonhosted.org/packages/e1/87/78806b0e39633d552b322c09b04b121396b2751af92d02682c5d7c95c891/fttlib-1.1.7-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "628dadfd1cd1f9bb4e36009e436b79b35ea97a0472d5298bdb572d2262562349",
                "md5": "45dd803602e630a68fc54e7e310d0c76",
                "sha256": "7054712acffa5b324808a44cfea42e4a16a162f0fd4b99797a27104ec02a115a"
            },
            "downloads": -1,
            "filename": "fttlib-1.1.7.tar.gz",
            "has_sig": false,
            "md5_digest": "45dd803602e630a68fc54e7e310d0c76",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 62246,
            "upload_time": "2024-09-19T21:21:27",
            "upload_time_iso_8601": "2024-09-19T21:21:27.757532Z",
            "url": "https://files.pythonhosted.org/packages/62/8d/adfd1cd1f9bb4e36009e436b79b35ea97a0472d5298bdb572d2262562349/fttlib-1.1.7.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-09-19 21:21:27",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "brondavies",
    "github_project": "filetypetranslator",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "fttlib"
}
        
Elapsed time: 0.34102s